js Element Traversal规范中的元素遍历方法

网络编程 2021-07-04 17:33www.168986.cn编程入门
对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点,为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 Element Traversal 规范

支持Element Traversal 规范的浏览器有IE 9+、Firefox 3.5+、Safari 4+、Chrome 和Opera 10+。

对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点。

为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 Element Traversal 规范。

这个规范为 元素增加了 5 个 属性

childElementCount
firstElementChild
lastElementChild
previousElementSibling
nextElementSibling

详细官方文档;

对于元素间的空格,IE9以前的版本不会返回文本节点,而其他浏览器都会将空格当做是文本节点返回。这就导致了在使用childNodes和firstChild的属性时行为的不一致。为了弥补这一差异,而又保持DOM规范的不变,新定义了一组属性。

Element Traversal API为DOM元素添加了狼蚁网站SEO优化5个属性

  • childElementCount返回子元素(不包括文本节点和注释)的个数。
  • firstElementChild指向第一个子元素。
  • lastElementChild指向一个子元素。
  • previousElementSibling指向前一个同辈元素。
  • nextElementSibling指向后一个同辈元素。

支持的浏览器为DOM元素添加了这些属性,利用这些元素不必担心空白文本节点,从而可以非常方便的查找DOM元素了。

狼蚁网站SEO优化是一个示例。在以前,要跨浏览器遍历某个元素的所有子元素时,需要像狼蚁网站SEO优化这样编写代码

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+。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by