文档中所有的节点之间都存在这样或那样的关系。节点间的各种关系可以用传统的家族关系来描述,相当于把文档树比喻成家谱。在HTML中,可以将元素看成是元素的子元素;相应地,也就可以将元素看成是元素的父元素。而元素,则可以看成是元素的同胞元素,因为它们都是同一个父元素的直接子元素。
每个节点都有一个childNodes属性,其中保存着一个NodeLiist对象。NodeList是一种类数组对象,用于保存一组有序的节点,可以通过位置来访问这些节点。请注意,虽然可以通过方括号语法来访问NodeList的值,而且这个对象也有length属性,但它并不是Array的实例。NodeList对象的独特之处在于,它实际上是基于DOM结构动态执行查询的结果,因此DOM结构的变化能够自动反映在NodeList对象中。我们常说,NodeList是有生命、有呼吸的对象,而不是在我们第一次访问它们的某个瞬间拍摄下来的一张快照。
下面的例子展示了如何访问保存在NodeList中的节点——可以通过方括号,也可以使用item()
方法:
var firstChild=someNode.childNodes[0];
var secondChild=someNode.childNodes.item (1);
var count=someNode.childNodes.length;
无论使用方括号还是使用item()方法都没有问题,但使用方括号语法看起来与访问数组相似,因此颇受一些开发人员的青睐。另外,要注意length属性表示的是访问NodeList的那一刻,其中包含的节点数量。我们在本书前面介绍过,对arguments对象使用Array.prototype.slice()方法;可以将其转换为数组。而采用同样的方法,也可以将NodeList对象转换为数组。来看下面的例子:
//在IE中无效
var arrayofNodes=Array.prototype.slice.call( someNode.childNodes,0);
除IE之外,这行代码能在任何浏览器中运行。由于IE将NodeList实现为一个COM对象,而我们不能像使用JScript对象那样使用这种对象,因此上面的代码在IE中会导致错误。要想在IE中将NodeList转换为数组,必须手动枚举所有成员。下列代码在所有浏览器中都可以运行:
function convertToArray( nodes){
var array=null;
try{
array=Array.prototype.slice.call( nodes,0);//针对非IE浏览器
) catch (ex) {
array=new Array();
for (var i=0. len=nodes.length;i array.push (nodes [i]);
}
}
return array;
}
这个convertToArray()函数首先尝试了创建数组的最简单方式。如果导致了错误(说明是在IE中),则通过try-catch块来捕获错误,然后手动创建数组。这是另一种检测怪癖的形式。
每个节点都有一个parentNode属性.该属性指向文档树中的父节点。包含在childNodes列表中的所有节点都具有相同的父节点,因此它们的parentNode属性都指向同一个节点。此外,包含在childNodes列表中的每个节点相互之间都是同胞节点。通过使用列表中每个节点的previousSibling和nextSibling属性,可以访问同一列表中的其他节点。列表中第一个节点的previousSibling属性值为null,向列表中最后一个节点的nextSibling属性的值同样也为null,如下面的例子所示:
if ( someNode.nextSibling===null)(
alert("Last node in the parent ' s childlNodes list.");
} else if (someNode.previousSibling===null){
alert("First node in the parent' s childNodes list.");
}
当然,南昌网站设计公司技术人员提示如果列表中只有一个节点,那么该节点的nextSibling和previousSibling都为null。
父节点与其第一个和最后一个子节点之间也存在特殊关系。父节点的firstChild和lastChild属性分别指向其childNodes列表中的第一个和最后一个节点。其中,someNode.firstChild的值始终等于someNode.childNodes[O],而someNode.lasChild的值始终等于someNode.childNodes[someNode.childNodes.length-l]。在只有一个子节点的情况下,firstChild和lastChild指向同一个节点。如果没有子节点,那么firstChild和lastChild的值均为null。明确这些关系能够对我们查找和访问文档结构中的节点提供极大的便利。图10-2形象地展示了上述关系。
在反映这些关系的所有属性当中,childNodes属性与其他属性相比更方便一些,因为只须使用简单的关系指针,就可以通过它访问文档树中的任何节点。另外,hasChildNodes()也是一个非常有
用的方法,这个方法在节点包含一或多个子节点的情况下返回true;应该说,这是比查询childNodes
列表的length属性更简单的方法。
所有节点都有的最后一个属性是ownerDocument,该属性指向表示整个文档的文档节点。这种关系表示的是任何节点都属于它所在的文档,任何节点都不能同时存在于两个或更多个文档中。通过这个属性,我们可以不必在节点层次中通过层层回溯到达顶端,而是可以直接访问文档节点。
虽然所有节点类型都继承自Node,但并不是每种节点都有子节点,我们将会讨论不同节点类型之间的差异.
本文仅限内部技术人员学习交流,不得作于其他商业用途.原创文章出自:南昌网站建设公司-百恒网络 http://www.jxbh.cn 如转载请注明出处!