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


Posted in Javascript onApril 19, 2018

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

Javascript 相关文章推荐
jqPlot Option配置对象详解
Jul 25 Javascript
JavaScript页面刷新与弹出窗口问题的解决方法
Mar 02 Javascript
利用jQuery的deferred对象实现异步按顺序加载JS文件
Mar 17 Javascript
JSONP跨域请求实例详解
Jul 04 Javascript
Node.js的文件权限及读写flag详解
Oct 11 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
bootstrap模态框实现拖拽效果
Dec 14 Javascript
详解浏览器缓存和webpack缓存配置
Jul 06 Javascript
老生常谈JS中的继承及实现代码
Jul 06 Javascript
javascript对HTML字符转义与反转义
Dec 13 Javascript
详解webpack引用jquery(第三方模块)的三种办法
Aug 21 jQuery
js轮播图之旋转木马效果
Oct 13 Javascript
关于vue中的ajax请求和axios包问题
Apr 19 #Javascript
详解vue 数据传递的方法
Apr 19 #Javascript
Vue 去除路径中的#号
Apr 19 #Javascript
详解vue中点击空白处隐藏div的实现(用指令实现)
Apr 19 #Javascript
基于JS实现html中placeholder属性提示文字效果示例
Apr 19 #Javascript
JS实现的倒计时恢复按钮点击功能【可用于协议阅读倒计时】
Apr 19 #Javascript
JS使用setInterval实现的简单计时器功能示例
Apr 19 #Javascript
You might like
作为PHP程序员应该了解MongoDB的五件事
2013/06/03 PHP
php数组转换js数组操作及json_encode的用法详解
2013/10/26 PHP
使用php清除bom示例
2014/03/03 PHP
PHP中Http协议post请求参数
2015/11/02 PHP
变量在 PHP7 内部的实现(二)
2015/12/21 PHP
文本框回车提交与禁止提交示例
2013/09/27 Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
2015/12/31 Javascript
Java框架SSH结合Easyui控件实现省市县三级联动示例解析
2016/06/12 Javascript
AngularJS API之copy深拷贝详解及实例
2016/09/14 Javascript
jquery css实现邮箱自动补全
2016/11/14 Javascript
JS定时检测任务任务完成后执行下一步的解决办法
2016/12/22 Javascript
jQuery实现扑克正反面翻牌效果
2017/03/10 Javascript
JS排序之冒泡排序详解
2017/04/08 Javascript
手把手搭建安装基于windows的Vue.js运行环境
2017/06/12 Javascript
AngularJS实现页面跳转后自动弹出对话框实例代码
2017/08/02 Javascript
js console.log打印对象时属性缺失的解决方法
2019/05/23 Javascript
Python使用xlrd模块操作Excel数据导入的方法
2015/05/26 Python
[原创]windows下Anaconda的安装与配置正解(Anaconda入门教程)
2018/04/05 Python
python 自定义对象的打印方法
2019/01/12 Python
Python OrderedDict的使用案例解析
2019/10/25 Python
Django多进程滚动日志问题解决方案
2019/12/17 Python
使用Python爬虫库requests发送表单数据和JSON数据
2020/01/25 Python
HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述
2013/01/30 HTML / CSS
HTML5 3D衣服摇摆动画特效
2016/03/17 HTML / CSS
有750多个顶级品牌的瑞士时尚在线:ABOUT YOU
2017/01/04 全球购物
伦敦剧院门票:London Theatre Direct
2018/11/21 全球购物
比利时家具购买网站:Home24
2019/01/03 全球购物
什么是命名空间(NameSpace)
2015/11/24 面试题
使用Vue.js和MJML创建响应式电子邮件
2021/03/23 Vue.js
煤矿机修工岗位职责
2014/02/07 职场文书
委托代理人授权委托书范本
2014/09/24 职场文书
离婚财产分隔协议书
2014/10/23 职场文书
党的群众路线教育实践活动整改落实情况报告
2014/10/28 职场文书
公司食堂管理制度
2015/08/05 职场文书
Python机器学习之基础概述
2021/05/19 Python
Redis高并发防止秒杀超卖实战源码解决方案
2021/11/01 Redis