最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:16:32
文档

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

js Element Traversal规范中的元素遍历方法:支持Element Traversal 规范的浏览器有IE 9+、Firefox 3.5+、Safari 4+、Chrome 和Opera 10+。 对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点。 为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 E
推荐度:
导读js Element Traversal规范中的元素遍历方法:支持Element Traversal 规范的浏览器有IE 9+、Firefox 3.5+、Safari 4+、Chrome 和Opera 10+。 对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点。 为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 E


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

    文档

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

    js Element Traversal规范中的元素遍历方法:支持Element Traversal 规范的浏览器有IE 9+、Firefox 3.5+、Safari 4+、Chrome 和Opera 10+。 对于元素间的空格,在IE9之前,都不会返回文档节点,其它的所有浏览器都会返回文档节点。 为了兼容浏览器这间的差异,又不更改已有的DOM 标准,所以有了 E
    推荐度:
    标签: 元素 js 遍历
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top