DOM元素的遍历

DOM为文档的每个节点都提供了childNodes属性,该属性返回一个nodeList对象。使用该属性可以对节点的子节点进行遍历。

但是更多的我们只是想遍历某一元素的子元素,此时该属性就不适用这种情况了。

原因是:当元素内出现空格时,该属性在不同浏览器下的行为不一致,IE9之前的版本不会返回文本节点,而其他浏览器返回的节点包括文本节点。

<ul>
  <li>1</li>
  <li>2</li>
  <li>3</li>
</ul>
var ul = document.getElementsByTagName('ul')[0];
var len = ul.childNodes.length;
console.log(len);  //IE9之前的版本返回3,而其他浏览器则返回7

从以上的代码可以看出,当我们只想遍历元素的子元素时,使用childNodes并不能理想的得到我们想要的结果。

DOM扩展为DOM元素提供了新的属性可以解决这些问题,这些属性包括:

  1. childElementCount //返回子元素的个数(不包括文本和注释节点)
  2. firstElementChild //指向第一个子元素,firstChild的元素版
  3. lastElementChild //指向最后一个子元素,lastChild的元素版
  4. previousElementSibling //指向前一个同辈元素,previousSibling的元素版
  5. nextElementSibling //指向后一个同辈元素,nextSibling的元素版

支持这些属性的浏览器包括:IE9+,Firefox 3.5+,Safari 4+,chrome和Opera 10+,在这些浏览器中,可以方便的对元素进行遍历,而不用担心空白的文本节点。

IE提出的children属性,也可以方便的对元素的子元素进行遍历,它返回元素中同样还是元素的子节点,值为HTMLCollection的集合。

支持 children 属性 的 浏览器 有 IE5、 Firefox 3. 5、 Safari 2( 但 有 bug)、 Safari 3( 完全 支持)、 Opera8 和 Chrome( 所有 版本)。 IE8 及 更早 版本 的 children 属性 中 也会 包含 注释 节点, 但 IE9 之后 的 版本 则 只 返回 元素 节点。

本文属性Js高程读后感

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 今日阳光很好。。。 和同事小聚,不辜负这个元宵节
    普通不平庸阅读 182评论 0 0
  • 萤火虫萤火虫慢慢飞, 夏夜里夏夜里风轻吹, 怕黑的孩子安静睡吧, 有萤火虫给你一点光。 ——《萤火虫》 小小的萤火...
    淡墨鲤阅读 591评论 1 8
  • 雪山之约 December 24, 2013 十年前一个雪山的约定,是一个勇敢的约定,要冲破重重的冰雪障碍。 有人...
    Michael叶阅读 352评论 0 3
  • 你心地善良,总能发现别人的优点,考虑他人的感受;你心怀感恩,那些温暖过自己的人和事,深深地烙在心底;你努力工作,使...
    栗花菇阅读 155评论 0 0
  • 2018年的三月,这几件事值得记录。 3月5号,女儿上幼儿园。 3月9号-3月11号,我参加了正面管教家庭讲师认证...
    犹树阅读 324评论 1 0