js如何进行元素遍历

这次给大家带来js如何进行元素遍历,js进行元素遍历的注意事项有哪些,下面就是实战案例,一起来看一下。

支持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;}

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

如何操作Vue做出proxy代理

如何操作Vue做出proxy代理

以上就是js如何进行元素遍历的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3187728.html

(0)
上一篇 2025年3月31日 23:13:49
下一篇 2025年3月31日 23:14:03

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JS实现简易版贪吃蛇小游戏

    nbsp;html PUBLIC “-//W3C//DTD XHTML 1.0 Strict//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd”>    新建网页     …

    编程技术 2025年4月4日
    200
  • phpstorm怎么用js

    一、PHPStorm调试Javascript 在PHPStorm中创建test.html nbsp;html>        Test page     var test; var test2; console.log(“hello …

    2025年4月2日 编程技术
    200
  • vscode怎么压缩js代码

    vscode压缩js代码的方法: 1、在拓展商店里搜索“minify”,安装,安装成功后点重新加载 2、使用:F1运行文件缩小器Minify压缩js代码。 使用Minify的方法介绍: 缩小您的js,css和html文件以节省传输带宽。直接…

    2025年4月2日
    200
  • 怎么在vscode中调试js代码

    在左侧扩展中搜索debugger for chrome并点击安装 在自己的html工程目录下面点击f5,或者在左侧选择调试按钮 选择下拉按钮,会有一个添加,选择chrome 之后会出现laungh.json的配置文件在自己的项目目录下面 不…

    2025年4月2日 编程技术
    200
  • vscode如何配置js运行环境

    vscode界面很简洁安装完之后所有的功能都一目了然,我们需要安装插件可以点击如图的工具和语言: 安装以下两个插件如图:(你也可以选择其他这里只是示例) 我们要调试一个js,需要创建一个html文档里面添加js方法,简单创建个文件,可以直接…

    2025年4月2日 编程技术
    100
  • vue.js核心最基本的功能是什么

    vue.js核心最基本的功能是一个允许采用简洁的模板语法来声明式地将数据渲染进DOM的系统。vue.js的核心功能使得我们可以很方便地控制切换一个元素是否显示。 本文操作环境:windows10系统、vue 2.5.2、thinkpad t…

    2025年4月1日
    400
  • 怎么用JavaScript在Vue3中实现动画?

    概述 动画的实现其实不仅可以使用css的方式实现,而且还可以使用js的方式实现,二者有啥区别呢?css更加注重动画的展现,性能更好,而js的方式性能稍微差点,但是可以在动画执行的每一个过程中做些额外的操作。也就是说动画执行的开始-执行中-结…

    编程技术 2025年4月1日
    200
  • 利用JS实现点击按钮后图片自动切换的简单方法

    我么常常看到一个网站的主界面的图片可以切换自如,那么又是如何实现的呢? 1.HTML页面布局如图所示: 2.实现上述布局 swap.html    nbsp;html PUBLIC ‘-//W3C//DTD HTML 4.01 Strict…

    2025年4月1日
    200
  • 利用JS+HTML5实现图片上传预览效果(实例)

    这篇文章主要介绍了js+html5实现上传图片预览效果,结合完整实例形式分析了javascript上传图片本地预览的具体操作步骤与相关实现技巧,需要的朋友可以参考下 本文实例讲述了JS+HTML5实现上传图片预览效果。分享给大家供大家参考,…

    编程技术 2025年4月1日
    100
  • js停止冒泡的实例详解

    div { background-color: green; border: 1px solid; padding: 50px;} 实例演示了在添加不同事件监听时,冒泡与捕获的不同。 点击段落,我是冒泡。   点击段落,我是捕获。 func…

    2025年4月1日
    100

发表回复

登录后才能评论