js下 Day02、DOM文档对象模型
一.DOM简介
Document Object Model 文档对象模型
DOM包含了所有HTML元素的属性和方法,以及访问他们的方式;
#二.DOM节点
#1. 什么是节点?
HTML中所有的元素都是一个节点
整个文档是文档节点
所有的标签都是元素节点
标签内的属性是属性节点
标签内的文本是文本
#2. 节点属性
| Ele.nodeName | Ele.nodeType | Ele.nodeValue | |
|---|---|---|---|
| 元素节点 | 大写的标签名 | 1 | null |
| 属性节点 | 属性名 | 2 | 属性值 |
| 文本节点 | #text | 3 | 文本内容 |
| 注释节点 | #comment | 8 | 注释内容 |
| 文档节点 | #document | 9 | null |
***\ ** ** 元素的tagName等价于nodeName
#3. 节点关系
会识别空白文本(不常用)
元素.firstChild 第一个子节点
元素.lastChild 最后一个子节点
元素.childNodes 获取所有的子节点
元素.attributes 获取某个元素的所有属性节点
元素.nextSibling 获取下一个兄弟节点
元素.previousSibling 获取上一个兄弟节点
不识别空白文本
元素.children 获取所有的元素子节点
元素.firstElementChild 获取第一个元素子节点
元素.lastElementChild 获取最后一个元素子节点
元素.nextElementSibling 获取下一个元素兄弟节点
元素.previousElementSibling 获取上一个元素兄弟节点
元素.parentNode 父节点
#三.查找元素
语法:元素.getElementById(“id”)
功能:通过id名查找元素
返回值:DOM对象
语法:元素.getElementsByTagName(“tag”)
功能:通过标签名查找元素
返回值:类数组
语法:元素.getElementsByClassName(“class”)
功能:通过class名查找元素
返回值:类数组
语法:元素.querySelector("css选择器");
功能:根据css选择器查找,只找一个
返回值:DOM对象
语法:元素.querySelectorAll("css选择器");
功能:根据css选择器查找,找所有
返回值:类数组
类数组转数组:
**[... ** 类数组];
Array.from(类数组);
#四.元素类名
classList: 所有类名组成的类数组
classList.add() 添加类名
classList.remove() 删除类名
classList.contains() 检测类名是否存在,返回布尔值
classList.toggle() 类名存在则删除,类名不存在则添加
#五.课堂案例
#1. 选中高亮
效果图
功能思路分析:
\1. 给每一个li绑定点击事件(forEach)
\2. 点击事件中,利用排他思想,先去掉所有标签的类名
\3. 再给当前标签加上类名

#2.手风琴
效果图:

功能思路分析:
\1. 给每一个li绑定点击事件(forEach)
\2. 点击事件中,利用排他思想,先去掉所有标签的类名
\3. 再给当前标签加上类名
#3.选项卡
效果图

功能思路分析:
\1. 淡入淡出效果需要先将所有的图片定位在一起,修改他们的透明度(opacity)
\2. 给每一个导航信息绑定点击事件
\3. 点击事件中,利用排他思想去掉所有的类名,并找到对应下标的图片去掉类名
\4. 给点击的元素加上类名,并找到对应下标的图片加上类名(classList.add)

#六.今日小结
1.节点关系: firstElementChild lastElementChild
previousElementSibling nextElementSibling
children parentNode
2.查找元素: document.querySelector( ‘css选择器’)
document.querySelector( ‘css选择器’)
3.类名操作: classList.add() classList.remove()
classList.contains() classList.toggle()
#七.作业 -- 轮播图
将案例3选项卡改编成轮播图效果
\1. 加上定时器(setInterval)自动轮播
\2. 添加左右箭头,上一页下一页切换
js下 Day02、DOM文档对象模型的更多相关文章
- JS第二部分--DOM文档对象模型
一.DOM的概念 二.DOM可以做什么 三.DOM对象的获取 四.事件的介绍 五.DOM节点标签样式属性的操作 六.DOM节点对象对值的操作 七.DOM节点-标签属性的操作(例如id class sr ...
- 认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。元素、属性和文本的树结构(节点树)。
认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...
- xml.dom——文档对象模型API
文档对象模型,或者“DOM”,是一个跨语言API的World Wide Web Consortium(W3C)来访问和修改XML文档.DOM的实现提供了一个XML文档树结构,或允许客户机代码从头开始建 ...
- Javascript - DOM文档对象模型
文档对象模型(DOM) DOM(Document Object Model,文档对象模型)是一个通过和JavaScript进行内容交互的APIJavascript和DOM一般经常作为一个整体,因为Ja ...
- JavaScirpt(JS)——DOM文档对象模型
一.HTML DOM介绍 HTML DOM 是 W3C 标准(是 HTML 文档对象模型的英文缩写,Document Object Model for HTML). HTML DOM 定义了用于 HT ...
- JavaScript学习笔记7 之DOM文档对象模型
一.什么是DOMDocument Object Model 文档 -------对象 ----模型-------缩写DOM DOM是针对HTML和XML文档的一个API(应用程序编程接口).DOM描绘 ...
- DOM 文档对象模型
document 对象(作为对象),是 DOM 的核心作用:对内容,属性,样式等操作属性:title:设置/返回当前文档的标题url:返回当前文档的 urlinnerHTML:获取指定对象内的内容bg ...
- JavaScript学习总结(一)DOM文档对象模型
一.文档(D) 一个网页运行在浏览器中,他就是一个文档对象. 二.对象(O) "对象"是一种自足的数据集合.与某个特定对象相关联的变量被称为这个对象的属性,只能通过某个对象调用的函 ...
- DOM文档对象模型
随机推荐
- Guitar Pro的10个非常实用的技巧(上)
Guitar Pro 7具有许多功能和编辑选项,只需点击几下即可随时创建与编辑我们的乐谱,.以下就为大家介绍10个Guitar Pro中实用的技巧,可以大大的节省我们的时间. 在开始之前,重要的是要知 ...
- ABBYY FineReader 15 对比文档功能
想必大家在办公的时候都有着要处理各种各样文档的烦恼,一个文档经过一个人或不同人的多次修订都是常有的事,拥有文档对比功能的软件也就应势而生.ABBYY FineReader 15 有许多能够帮助我们办公 ...
- [配置]01.IntelliJ IDEA代码格式化与Eclipse保持风格一致
- 【P1972】HH的项链——树状数组+询问离线
(题面摘自luogu) 题目背景 无 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断地收集 ...
- 公平lock和非公平lock的区别
可以看到区别在于,在lock时和tryAquire时,非公平锁不会去管队列中有没有线程在排队,直接尝试去获取锁,失败之后就和公平锁一样,乖乖去排队. 也就是说发生竞争的场景在于,尚未入队的线程之间和刚 ...
- 区块链V1版本实现之二
部分程序代码(生成并调用hash代码): 1 //创建区块,对Block的每一个字段填充数据 2 func NewBlock(data string, prevBlockHash []byte) *B ...
- 浅谈代理模式与java中的动态代理
代理模式的定义: 代理模式是一个使用律非常高的模式,定义如下: 为其他对象提供一种代理,以控制对这个对象的访问. 类图: 简单的静态代理: public interface IRunner{ //这是 ...
- 怎么用fio测试存储性能
1 /// -rw=read(100%顺序读) -rw=write(100%顺序写) -rw=randread(100%随机读) -rw=randwrite(100%随机写), 2 ///-rw=rw ...
- Centos7配置阿里epel源|yum源
这一步非常重要.重要.重要.在这解释一下源的概念,打个比方如果手机想获取一个软件,可以选择很多途径,如华为的华为商店,小米的应用商店,苹果的App store,源就相当于各种手机获取软件的商店.因为国 ...
- day3(使用axios实现登录成功)
1.创建一个login.vue页面 1.1写页面components/Login.vue 在 src/components 下创建 Login.vue 页面 <template> &l ...