12、DOM

一、什么是DOM

DOM是Document Object Model(文档对象模型)的缩写 ,由w3c制定Web标准 

二、节点类型(了解)

1、每个节点都有一个nodeType属性,用于表明节点的类型。

2、常用节点类型与对应nodeType值:

备注:
用于判断获取到的元素属于什么类型节点
元素节点 <==> 1
文本节点 <==> 3
属性节点 <==> 2

三、获取元素节点(2、3条可以通过任意元素对象去调用)

1、document.getElementById("id名")
*、获取id名所在的元素(速度最快) ,返回值为元素对象或者null
*、须通过document调用
2、getElementsByClassName("class名")
* 获取到类名所在的元素组成的类数组。通过索引操作具体元素对象。返回值为类数组或者[]。
* 元素节点均可调用
3、getElementsByTagName("标签名")
* 获取到标签名所在的元素组成的类数组。通过索引获取到具体的元素
* 元素节点均可调用
4、document.getElementsByName("名字")
* 获取到**表单**名字所在的元素组成的类数组
*必须通过document调用

5、获取body及html

document.body   ==> 获取body
document.documentElement ==> 获取html

四、利用节点关系,获取所有节点

利用节点关系,获取元素、文本节点利用元素关系,获取元素节点
获取父级节点:ele.parentNode * 得到节点的父节点 获取父级节点:ele.parentElement * 得到节点的父元素节点
获取子节点:ele.childNodes * 得到ele元素的全部子节点列表(类数组) ele.firstChild * 获得ele元素的第一个子节点 ele.lastChild * 获得ele元素的最后一个子节点 获取子节点:ele.children * 得到ele元素的全部子元素节点列表ele.firstElementChild * 获得ele元素的第一个子节点ele.lastElementChild * 获得ele元素的最后一个子节点
获取兄弟节点:ele.nextSibling * 获得节点的下一个兄弟节点ele.previousSibling * 得到节点的上一个兄弟节点 获取兄弟节点:ele.nextElementSibling * 获得节点的下一个兄弟节点ele.previousElementSibling * 得到节点的上一个兄弟节点

 

五、三大节点的三大属性

1、元素节点
* nodeType 1
* nodeName 元素名大写
* nodeValue null
2、属性节点
* nodeType 2
* nodeName 属性名
* nodeValue 属性值
3. 文本节点
* nodeType 3
* nodeName #text
* nodeValue 文本内容

六、节点的增删改查

1、节点的创建
(1) document.**createElement**(“标签名”)
* 创建一个元素节点

(2) document.createTextNode(“文本”)
* 创建文本节点(了解)

(3) document.createAttribute(“属性名”)
* 创建一个属性节点(了解)
2、节点的插入
备注:以下parent表示父级元素,ele表示元素
(1) parent.appendChild(插入的节点)  
* 向节点的子节点列表的结尾添加新的子节点

(2) parent.insertBefore(new,node)  
* 在指定的子节点node前插入新的子节点new。

例:往子节点前面插入一个新节点
var h2 = document.createElement('h2');
h2.innerHTML = '哈哈哈';
document.body.insertBefore(h2,h3);

(3) ele.setAttributeNode(attrNode)
* 在指定元素中插入一个属性节点(了解)
演示:利用创建节点方法,生成三种节点,并往元素节点插入内容及属性
1.创建元素节点
var h3 = document.createElement("h3");

2.创建文本节点,并往h3元素节点插入文本节点
var txt = document.createTextNode("啦啦啦");
h3.appendChild(txt);
常用方法 =====> h3.innerHTML = "啦啦啦";

3.创建属性节点,并往h3元素节点插入属性节点
var title = document.createAttribute("title");
title.nodeValue = 'xxx';
h3.setAttributeNode(title);
常用方法 =====> h3.title = "xxx"

4.将元素节点插入body里面
document.body.appendChild(h1);
案例:生成表格
 1 //1.获取文本框、按钮、及输出元素
 2 //2.封装表格函数(保证单一原则,即一个函数只做一件事)
 3     function createTable(r,c){
 4         //2.1 创建table>tbody>tr>td,记得插入对应的父元素内
 5         //2.2 将table返回出去
 6     }
 7 //3.点击按钮时
 8     //2.1 获取行列值
 9     //2.2 执行生成表格函数
10     //2.3 将表格插入输出元素
11     //2.4 注意事项:每次插入前,记得清空上一次插入的内容
12         output.innerHTML = '';
13         output.appendChild(table);
案例:自动应答机器人
 1 // 1.获取输出元素ul、输入框及按钮
 2 // 3.设置应答消息,用数组方式存放
 3     var q = '你好,在吗,约吗,十年了还约吗'.split(',');
 4     var a = '他好我也好,不是本人,叔叔在哪约,滚'.split(',');
 5 // 2.点击按钮,发送信息(.active)
 6 btn.onclick = function(){
 7     //2.1 发送信息(即在ul内插入li,并设置类名):
 8     //2.2 发送自动应答信息(设置延迟n秒,setTimeout)
 9     // 注意:利用发送信息在q数组的索引,获取a数组中自动回复的内容
10     var idx = q.indexOf(_msg);
11     if(idx >= 0){
12         aLi.innerHTML = a[idx];
13     }else{  
14         aLi.innerHTML = '你说什么?风太大我听不到';
15     }   
16     //2.3 清空内容,自动聚焦
17     msg.value = '';
18     msg.focus();
19 }   
3、节点的删除、复制、判断方法
删除:
(1) 父节点.removeChild(ele)
* 删除(并返回)当前节点parent的指定子节点ele。
* 父节点删除子节点

复制:
(2) 当前节点.cloneNode(boolean)
* 复制节点,boolean为true是深复制。返回值为复制后的新节点

判断:
(3) 父节点.hasChildNodes()
* 判断当前节点是否拥有子节点,返回布尔值当有参数时判断是否有这个子节点
案例:表格删除、复制表格行
 1 *添加行号
 2 *添加删除按钮
 3 *删除当前行(一定要书写在生成表格后)
 4     *获取所有按钮
 5     *分别给所有按钮绑定事件处理函数
 6 for(var i=0;i<btnDels.length;i++){
 7     btnDels[i].onclick = function(){
 8         //console.log(i)//演示:不管点击哪个按钮,最终都会得到10(变量查找规则)
 9         //利用当前对象this,删除当前行tr、
10     }
11     //*添加复制功能,复制行
12     btnCopies[i].onclick = function(){
13         // 获取当前行
14         var currentTr = this.parentNode.parentNode;
15         // 复制tr
16         var copyTr = currentTr.cloneNode(true);
17         // !!!问题:复制的tr没有事件,为什么,怎么解决?
18         table.getElementsByTagName('tbody')[0].appendChild(copyTr);
19     }
20 }

七、节点的属性及方法

* 节点是对象,给对象添加属性与给html元素添加属性不是一个意思。
* html标准属性会互相影响,但是不是标准的属性不会互相影响。
1、节点(对象)的属性
(1.1)tagName 获取元素元素的标签名
(1.2)className 设置/获取元素的class属性
(1.3)id 设置/获取元素id属性
(1.4)name 设置/获取元素name属性
(1.5)style 设置/获取元素的内联样式
(1.6)innerHTML 设置/获取元素的内容(包含html代码)
(1.7)innerText 设置或获取位于元素标签内的文本
2、节点的方法(操作html结构属性)
(2.1)ele.setAttribute(attr,val)("html属性","属性值") 
给html元素添加属性
(2.2)ele.getAttribute(attr)("html属性")
拿到html属性对应的属性值
(2.3)ele.removeAttribute(attr)("html属性")
删除html属性
(2.4) ele.hasAttribute(attr)("html属性") 判断是否存在html属性

八、节点的盒模型相关的属性

(1)offsetWidth: ==> 当前元素的宽度(border + padding + content)
(2)offsetHeight: ==> 当前元素的高度(border + padding + content)
(3)offsetLeft: ==> 当前元素离**<定位父级>**元素左边的距离。
(4)offsetTop ==> 当前元素离**<定位父级>**元素顶部的距离。

备注: 若不在定位父级,则相对于html的距离

九、操作css样式

(1) 元素.style.属性 = "属性值" ==> 只能操作内联样式
(2) window.getComputedStyle(ele,pseudo)
* ele:要获取样式的元素
* pseudo:伪元素样式字符(可选),可获取伪元素样式
(3) ele.currentStyle (IE8-)
* 得到包含ele所有样式的对象(支持IE8以下浏览器)
* currentStyle不能获得css总属性的值

十、图片解释

1、html结构与dom节点属性的共同点与不同点

2、节点的关系

 

* dom_tree

 

posted @ 2019-03-07 23:00  哎,我说  阅读(287)  评论(0编辑  收藏  举报