dom系列:Node操作

本文详细介绍了DOM中的Node对象及其属性和方法,包括nodeName、nodeValue、nodeType等重要属性,以及insertBefore、replaceChild等核心方法。此外还介绍了如何通过NodeList遍历节点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   阅读该内容之前,建议先阅读我写的《dom概述》
    在Dom中一切都是Node对象,而Element,TextNode,Attribute,Comment都是Node的子类。也就是说,Node对象 的所有属性和方法,对于Element,TextNode,Attribute,Comment都适用,并且Element,TextNode, Attribute,Comment提供了特殊的属性和方法来提了特殊作。
    Node对象的主要属性有:
    nodeName 节点的名称,对于TextNode来说,NodeName没有意义,在JavaScript中是#Text
    nodeValue节点的值,对于Element来说,nodeValue是null,对于文本节点来说nodeValue是文本本身
    nodeType 节点的类型,是文本节点、元素节点、还是属性节点呢?
    parentNode 节点的父节点。
    firstChild 第一个子结点
    lastChild 最后一个子结点。
    childNotes 所有的子结点的集合是一个NodeList对象,该对象不是java.util.List的子类,应该注意。
   对于Node节点的方法,主要的方法有:
    insertBefore (newChild, refChild) 把节点插入到refChild节点的前面,成为refChild的兄弟节点。注意dom中没有定义insertAfter方法。
    replaceChild (newChild, oldChild) 替换新节点。
    appendChild (newChild) 把新节点追加到自己的孩子节点的最后一个。是一个非常常用的方法。
    removeChild (oldChild) 删除一个指定的子节点。
    hasChildNodes() 判断该子结点是否还有子结点
    cloneNode() 复制一个子结点。
   以上是Node节点的重要方法。
    对于所有的节点都适用。但是在众多节点中,最让人关注的是Element节点,对该节点提供有灵活的方法来操作属性。
   element.setAttribute("name","value"),向Element中添加一个属性。Element对象的tagname属性 其实就是node的nodeName属性。getAttribute (attrName)方法可以轻松的获取Element中属性的值。removeAttribute (attrName)可以轻松的根据属性名称删除一个属性。
   
   在Node属性中有一个childNodes属性返回一个NodeList对象,该对象是一个Node对象的集合,不是java.util.List的子类,那么如何使用呢?该对象提供一个属性和一个方法非常方便的对NodeList集合提供遍历。
   length属性指出NodeList中有多少node对象。
   item (index) 方法可以检索childNodes对象中第index位置中的Node对象。
   示例:

NodeList nl = doc.getElementsByTagName_r("*");
Node n;
n = nl.item(0);
System.out.print(n.getNodeName());

掌握以上的Node的属性和方法,基本上操作dom就没有什么大问题了,如果你需要更多的dom操作,可以查阅w3c的文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值