共计 799 个字符,预计需要花费 2 分钟才能阅读完成。
对于元素间的空格,IE9 以前的版本不会返回文本节点,而其他浏览器都会将空格当做是文本节点返回。这就导致了在使用 childNodes
和firstChild
的属性时行为的不一致。为了弥补这一差异,而同时又保持 DOM 规范的不变,W3C Element Traversal 规范新定义了一组属性。
Element Traversal API 为 DOM 元素添加了下面 5 个属性:
childElementCount
:返回子元素(不包括文本节点和注释)的个数。firstElementChild
:指向第一个子元素。lastElementChild
:指向最后一个子元素。previousElementSibling
:指向前一个同辈元素。nextElementSibling
:指向后一个同辈元素。
支持的浏览器为 DOM 元素添加了这些属性,利用这些元素不必担心空白文本节点,从而可以非常方便的查找 DOM 元素了。
下面是一个示例。在以前,要跨浏览器遍历某个元素的所有子元素时,需要像下面这样编写代码:
var i,len,child = element.firstChild;
while(child != element.lastChild){if(child.nodeType == 1){processChild(child);
}
child = child.nextSibling;
}
而使用 Element Traversal 新增的属性,代码就会变得非常简洁:
var i,len,child = element.firstElementChild;
while(child != element.lastElementChild){processChild(child);
child = child.nextElementSibling;
}
支持 Element Traversal 规范的浏览器有:IE9+,Firfox3.5+,Safari4+,Chrome 和 Opera10+。
正文完