DOM节点树和元素树--深度遍历
我们在阅读JS高级程序设计的时候,提到了节点树的概念。比如说:
elem.parentNode---找elem的父节点;
elem.childNodes---找elem的所有的直接子节点;
elem.nextSibling---找elem的下一个同辈节点‘;
elem.previousSibling---找elem的上一个同辈节点
因为childNodes包含看不见的空格文本,还有注释等内容,所以使用起来不是太方便。
因此,JS又重新引入了元素树的概念。这个的话,在我们实际应用中,用的比较普遍。
元素树:仅仅包含元素节点的树结构,不是一颗新树,尽是节点数的子集;
elem.parentElement 找节点的父元素;
elem.children返回节点的所有子元素;
elem.firstElementChild 第一个直接子元素;
elem.lastElementChild 最后一个直接字元素;
elem.previousElementSibling 找elem的前一个兄弟元素;
elem.nextElementSibling 找elem的下个兄弟元素;
在这里,我们介绍一个笔试题:
遍历一个指定父节点下的所有后代节点,这里需要明确一点,就是所有的后代节点都需要遍历到:
1 <script type='text/javascript'>
2 function getChildren(parent){
//如果当前父节点不是文本节点,就输出标签名,否则输出文本内容
3 console.log(parent.nodeType!=3?parent.nodeName:parent.nodeValue);
//获得父节点的所有直接子节点
4 var children = parent.childNodes;
//遍历children中每个节点
5 for(var i =0,len =children.length;i<len;i++){
//Step2: 对当前子节点调用getChildren
6 getChildren(children[i]);//这里使用递归的调用方法;
7 //console.log(children[i].nodeType !=3?children[i].nodeName:children[i].nodeValue);
8 }
9 }
10 getChildren(document.body);
11 </script>
这里我们需要知道一个算法-----深度优先遍历:当同时有兄弟节点和子节点的时候,总是优先遍历子节点。
上面代码的遍历顺序,就是优先遍历子节点。
我们在高性能JS这本书学到过,就是递归的运行效率没有迭代的运行效率高,所以,我们优化的话,一般都需要把递归的循环优化成迭代的循环。
上面的例子如何修改呢,这里我们要提到一个新的概念,那就是:
NodeIterator 对象,可以对 DOM 树进行深度优先的搜索。
创建 NodeIterator 对象,需要使用 document 对象的 createNodeIterator() 方法,该方法接收四个参数:
- root,搜索开始的节点
- whatToShow,一个数值代码,表示哪些节点需要搜索
- filter,NodeFilter 对象,决定忽略哪些节点
- entityReferenceExpansion,布尔值,表示是否需要扩展实体引用
whatToShow 参数:
- NodeFilter.SHOW_ALL,显示所有节点
- NodeFilter.SHOW_ELEMENT,元素节点
- NodeFilter.SHOW_ATTRIBUTE,属性节点
- NodeFilter.SHOW_TEXT,文本节点
- NodeFilter.SHOW_CDATA_SECTION,
![CDATA]
节点 - NodeFilter.SHOW_ENTITY_REFERENCE,实体引用节点(
"
) - NodeFilter.SHOW_ENTITY,实体元素节点(
<!ENTITY foo "foo">
) - NodeFilter.SHOW_PROCESSING_INSTRUCTION,PI 节点
- NodeFilter.SHOW_COMMENT,XML 注释节点
- NodeFilter.SHOW_DOCUMENT,文档顶层节点
- NodeFilter.SHOW_DOCUMENT_TYPE,DTD 节点
- NodeFilter.SHOW_DOCUMENT_FRAGMNT
- NodeFilter.SHOW_NOTATION
- 我们重新修改后的代码如下:
- 1234567891011121314
function getChildren(parent){
//获取NodeIterator对象
var t = document.createNodeIterator(parent,NodeFilter.SHOW_ALL,null,false);
//循环遍历对象的下一个节点;
var currNode=null;while((currNode=t.nextNode())!=null){
//节点不为空,就一直循环遍历下去;直到为null,才中断循环;
console.log(node.nodeType!=3?node.nodeName:node.nodeValue)
}
}
getChildren(document.body);
DOM节点树和元素树--深度遍历的更多相关文章
- 006 DOM节点操作与元素的创建
一:节点 1.节本基本概念 节点主要有标签,属性,文本[包括文字,空格,换行,回车]. 2.节点的属性 可以使用标签,元素点出来 可以使用标签,点出来 可以使用文本,点出来 nodeType:1--标 ...
- js学习总结:DOM节点二(dom基本操作)
一.DOM继承树 DOM——Document Object Model DOM定义了表示修改文档所需要的方法.DOM对象即为宿主对象,由浏览器厂商定义,用来操作html和xml的一类厂商定义,也有人称 ...
- jQuery操作DOM节点的方法总结
1.parent():获得当前匹配元素集合中每个元素的父元素,该方法只会向上一级对 DOM 树进行遍历 $('li.item-a').parent().css('background-color', ...
- js中的DOM节点
文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法. DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 把上面的代码拆分为Dom节 ...
- childNodes遍历DOM节点树
childNodes遍历DOM节点树 var s = ""; function travel(space,node) { if(node.tagName){ s += space ...
- java遍历树(深度遍历和广度遍历
java遍历树如现有以下一颗树:A B B1 B11 B2 B22 C C ...
- 多级树的深度遍历与广度遍历(Java实现)
目录 多级树的深度遍历与广度遍历 节点模型 深度优先遍历 广度优先遍历 多级树的深度遍历与广度遍历 深度优先遍历与广度优先遍历其实是属于图算法的一种,多级树可以看做是一种特殊的图,所以多级数的深/广遍 ...
- DOM 元素的循环遍历
博客地址:https://ainyi.com/89 获取 DOM 元素的几种方式 get 方式: getElementById getElementsByTagName getElementsBy ...
- 深入理解DOM节点类型第五篇——元素节点Element
× 目录 [1]特征 [2]子节点 [3]特性操作[4]attributes 前面的话 元素节点Element非常常用,是DOM文档树的主要节点:元素节点是html标签元素的DOM化结果.元素节点主要 ...
随机推荐
- Mongoose 分页查询优化、获取数据总长度
无论是传统网页还是 ajax api,我们都不得不进行数据分页,一来节省带宽二来提升页面响应速度.作为一个数据完备的 web 应用,做好分页功能能极大提升用户体验. 简单的分页查询 在 mongoos ...
- 【已解决】wepy中使用分包加载报错
问题: "xxx.js 出现脚本错误后者未正确调用Page()" 最近看小程序启动时间(性能监控),启动时间比较长,所以考虑使用分包加载. 但在使用过程中遇 ...
- 数据库中"DDL","DML","DCL"
sql组成:DDL:数据库模式定义语言,关键字:createDML:数据操纵语言,关键字:Insert.delete.updateDCL:数据库控制语言 ,关键字:grant.removeDQL:数据 ...
- iOS(Swift)-Runtime之关于页面跳转的捷径【Runtime获取当前ViewController,很常用】
写在前面 在我们操作页面跳转时,如果当前的类不是UIViewcontroller(下面用VC表示),你会不会写一个代理,或者block给VC传递信息,然后在VC里面进行 ///假如targetVc是将 ...
- AppScan安全测试入门操作
appscan:可以对网站等 Web 应用进行自动化的应用安全扫描和测试,也就是经常说的安全测试 工作原理:是通过对web应用进行安全攻击来检查网站是否存在漏洞. 初步了解到的 创建新的扫描-> ...
- Xshell 命令后台执行
但是这样没有在后台启动:因此sh那一行代码需要修改: 前边加上nohup 后边加上& nohup dotnet helloword.dll & 然后,进程启动之后,按任意键进入输入状态 ...
- python中的sort方法使用详解
Python中的sort()方法用于数组排序,本文以实例形式对此加以详细说明: 一.基本形式 列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不 ...
- Office自动生成目录步骤(非常实用)(图文详解)
不多说,直接上干货! 结束 欢迎大家,加入我的微信公众号:大数据躺过的坑 人工智能躺过的坑 同时,大家可以关注我的个人博客: http://www.cnblogs.co ...
- go语言接受者的选取
何时使用值类型 1.如果接受者是一个 map,func 或者 chan,使用值类型(因为它们本身就是引用类型).2.如果接受者是一个 slice,并且方法不执行 reslice 操作,也不重新分配内存 ...
- zk使用原理
ZooKeeper的基本原理 ZNode的基本概念 ZooKeeper数据模型的结构与Unix文件系统很类似,整体上可以看作是一棵树,每个节点称做一个ZNode.每个ZNode都可以通过其路径唯一标识 ...