您的位置:首页 > Web前端 > HTML

使用DOM操作HTML文档

2010-07-23 15:02 507 查看
2009-07-24 22:25
使用DOM操作HTML文档
  Node对象定义了一系列属性和方法,来方便遍历整个文档。用parentNode属性和childNodes[]数组可以在文档树中上下移动;通过遍历childNodes[]数组或者使用firstChild和nextSibling属性进行循环操作,也可以使用lastChild和previousSibling进行逆向循环操作,也可以枚举指定节点的子节点。而调用appendChild()、insertBefore()、removeChild()、replaceChild()方法可以改变一个节点的子节点从而改变文档树。
  需要指出的是,childNodes[]的值实际上是一个NodeList对象。因此,可以通过遍历childNodes[]数组的每个元素,来枚举一个给定节点的所有子节点;通过递归,可以枚举树中的所有节点。下表列出了Node对象的一些常用属性和方法:

Node对象常用属性:

属性描述
attributes如果该节点是一个Element,则以NamedNodeMap形式返回该元素的属性。
childNodes以Node[]的形式存放当前节点的子节点。如果没有子节点,则返回空数组。
firstChild以Node的形式返回当前节点的第一个子节点。如果没有子节点,则为null。
lastChild以Node的形式返回当前节点的最后一个子节点。如果没有子节点,则为null。
nextSibling以Node的形式返回当前节点的兄弟下一个节点。如果没有这样的节点,则返回null。
nodeName节点的名字,Element节点则代表Element的标记名称。
nodeType代表节点的类型。
parentNode以Node的形式返回当前节点的父节点。如果没有父节点,则为null。
previousSibling以Node的形式返回紧挨当前节点、位于它之前的兄弟节点。如果没有这样的节点,则返回null。
  Node对象常用方法:

方法描述
appendChild()通过把一个节点增加到当前节点的childNodes[]组,给文档树增加节点。
cloneNode()复制当前节点,或者复制当前节点以及它的所有子孙节点。
hasChildNodes()如果当前节点拥有子节点,则将返回true。
insertBefore()给文档树插入一个节点,位置在当前节点的指定子节点之前。如果该节点已经存在,则删除之再插入到它的位置。
removeChild()从文档树中删除并返回指定的子节点。
replaceChild()从文档树中删除并返回指定的子节点,用另一个节点替换它。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: