JavaScript 操作DOM
目录
操作DOM
1、选择器
由于HTML文档被浏览器解析后就是一棵DOM树,要改变HTML的结构,就需要通过JavaScript来操作DOM。
始终记住DOM是一个树形结构。操作一个DOM节点实际上就是这么几个操作:
- 更新:更新该DOM节点的内容,相当于更新了该DOM节点表示的HTML的内容;
- 遍历:遍历该DOM节点下的子节点,以便进行进一步操作;
- 添加:在该DOM节点下新增一个子节点,相当于动态增加了一个HTML节点;
- 删除:将该节点从HTML中删除,相当于删掉了该DOM节点的内容以及它包含的所有子节点。
由于ID在HTML文档中是唯一的使用querySelector() 和querySelectorAll() ,需要了解selector语法,然后使用条件来获取节点,更加方便:
2、更新DOM
拿到一个DOM节点后,我们可以对它进行更新。可以直接修改节点的文本,方法有两种:
一种是修改innerHTML 属性,这个方式非常强大,不但可以修改一个DOM节点的文本内容,还可以直接通过HTML片段修改DOM节点内部的子树:
用innerHTML 时要注意,是否需要写入HTML。如果写入的字符串是通过网络拿到了,要注意对字符编码来避免XSS攻击。
第二种是修改innerText 属性,这样可以自动对字符串进行HTML编码,保证无法设置任何HTML标签:
修改CSS也是经常需要的操作。DOM节点的style 属性对应所有的CSS,可以直接获取或设置。因为CSS允许font-size 这样的名称,但它并非JavaScript有效的属性名,所以需要在JavaScript中改写为驼峰式命名fontSize :
3、插入DOM
appendChild
当我们获得了某个DOM节点,想在这个DOM节点内插入新的DOM
如果这个DOM节点是空的,例如, `,那么,直接使用innerHTML = 'child'`就可以修改DOM节点的内容,相当于“插入”了新的DOM节点。
如果这个DOM节点不是空的,那就不能这么做,因为innerHTML 会直接替换掉原来的所有子节点。有两个办法可以插入新的节点。一个是使用appendChild ,把一个子节点添加到父节点的最后一个
子节点。例如:
把JavaScript 添加到的最后一项:
现在,HTML结构变成了这样:
因为我们插入的js 节点已经存在于当前的文档树,因此这个节点首先会从原先的位置删除,再插入到新的位置。
insertBefore
如果我们要把子节点插入到指定的位置可以使用parentElement.insertBefore(newElement, referenceElement);
子节点会插入到referenceElement 之前。上面的HTML,我们要把Haskell 插入到Python 之前:
可以这么写:
新的HTML结构如下:
4、删除DOM
要删除一个节点,首先要获得该节点本身以及它的父节点,然后,调用父节点的removeChild 把自己删掉:
删除后的节点虽然不在文档树中了,但其实它还在内存中,可以随时再次被添加到别的位置。
当遍历一个父节点的子节点并进行删除操作时,children 属性是一个只读属性,并且它在子节点变化时会实时更新。