1.DOM的一些节点获取
<div id="grandpa">
<ul id="parent">
<li id="son" class="li1">1</li>
<li>2</li>
<li>3</li>
</ul>
</div>
var grand = document.getElementById('grandpa');
var parent = document.getElementById('parent');
var son = document.getElementById('son');
console.log(parent.parentNode);//获取DOM节点的父节点
console.log(parent.childNodes);//获取元素所有子节点,包括文本和空格
console.log(parent.firstChild);//获取元素的第一个子节点,包括文本及空格
console.log(parent.firstElementChild);//获取元素的第一个子节点,不包括文本及空格
console.log(parent.lastElementChild);//获取元素的最后一个子节点,不包括文本及空格
console.log(parent.children);//获取元素所有子节点,不包括文本和空格
console.log(son.nextSibling);//获取元素同级的相邻的节点(下一个),包括文本及空格
console.log(son.previousSibling);//获取元素同级的相邻的节点(前一个),包括文本及空格
console.log(son.nextElementSibling);//获取元素同级的相邻的节点(下一个),包括文本及空格
console.log(son.previousElementSibling);//获取元素同级的相邻的节点(前一个),包括文本及空格
console.log(son.attributes);//获取当前节点所有属性的集合
打印出的结果如下(图片中的结果与上面代码一一对应)
DOM节点的增删改查
- DOM节点的增加(appendChild和insertBefore)
例:
<ul id="ul1">
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
要想在ul中增加一个子节点li,先找到这个ul节点
var ul = document.getElementById('ul1')
然后创建一个li标签元素
var li = document.createElement('li');
li.innerText = 'hello world'
最后将这个li标签添加到ul中
appendChild
ul.appendChild(li)
运行后结果如下
appendChild是加在子元素的最后
insertBefore(插在指定的位置,有两个参数。第一个参数是要插入的节点,第二个参数是被插入的子节点)
ul.insertBefore(li,ul.firstElementChild);//将li插在ul的第一个标签元素节点前
运行结果如下
- DOM节点的删除
例:要将上面ul中最后一个子节点删除,代码如下
var li1 = document.getElementsByTagName('li');//获取所有li标签
ul.removeChild(li1[2]);
运行结果如下
- DOM节点的替换
例:将上面的ul中的第二个li节点换成新增的li节点,代码如下
ul.replaceChild(li,li1[2]);
结果如下
- DOM节点的复制
例:将上面ul中的第一个节点复制一次并添加到ul中,代码如下
var li2 = li1[0].cloneNode(true)//括号里的参数为布尔类型。true代表将这个节点下的所有内容全部复制,包括子代;false代表只复制这个标签;默认为false
ul.appendChild(li2)
结果如下