js Element Traversal规范中的元素遍历方法
2018-04-19 22:19
603 查看
支持Element Traversal 规范的浏览器有IE 9+、Firefox 3.5+、Safari 4+、Chrome 和Opera 10+。
对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点。
为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 Element Traversal 规范。
这个规范为 元素增加了 5 个 属性
childElementCount
firstElementChild
lastElementChild
previousElementSibling
nextElementSibling
详细官方文档; http://www.w3.org/TR/ElementTraversal/
对于元素间的空格,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+。
您可能感兴趣的文章:
相关文章推荐
- 遍历list集合删除指定元素方法
- C#遍历List并删除某个元素的方法
- java集合框架遍历元素方法总结
- js数组循环遍历数组内所有元素的方法
- Collection方法之五 对集合中元素进行遍历
- STL中用ERASE()方法遍历删除元素
- Java学习之容器上(Collection接口常用方法,Iterator接口,使用foreach循环遍历Collection集合元素,Set集合通用知识(Hashset类,hashcode()与Lin
- 数组的遍历和元素输出的四种方法
- STL中用erase()方法遍历删除元素
- STL中用ERASE()方法遍历删除元素
- vector, list, map在遍历时删除符合条件的元素实现方法
- STL::list 遍历元素方法
- C#遍历List并删除某个或者几个元素的方法
- Java学习之容器上(Collection接口常用方法,Iterator接口,使用foreach循环遍历Collection集合元素,Set集合通用知识(Hashset类,hashcode()与LinkedHashSet类))
- 遍历Linux kernel的链表时删除元素的方法
- STL中用ERASE()方法遍历删除元素
- STL中用erase()方法遍历删除元素
- ArrayList边遍历自身边删除元素的方法
- STL中迭代器失效——用erase()方法遍历删除元素
- STL中用erase()方法遍历删除元素