当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js Element Traversal规范中的元素遍历方法

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

2018年04月25日  | 移动技术网IT编程  | 我要评论
支持element traversal 规范的浏览器有ie 9+、firefox 3.5+、safari 4+、chrome 和opera 10+。 对于元素间的空格,在

支持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元素添加了下面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+。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网