热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

DOM树遍历之JS完成DFS&BFS

我们平常能够采纳DFS(深度优先遍历)和BFS(广度优先遍历)来遍历DOM树引见DFS&BFS我们来连系详细例子举行剖析,给出HTML代码片断以下:

我们平常能够采纳DFS(深度优先遍历)BFS(广度优先遍历)来遍历DOM树

引见 DFS & BFS

我们来连系详细例子举行剖析,给出HTML代码片断以下:









DFS老是先进入下一级节点,只要当下一级没有未遍历的子节点时才会进入到当前层级的别的节点。关于上面例子DFS遍历效果应为:

root, container, sidebar, menu, main, post, copyright

BFS则老是先遍历当前层级的一切节点,只要当当前层级一切节点都遍历完毕后才会进入下一层级。关于上面例子BFS遍历效果应为:

root, container, sidebar, main, menu, post, copyright

DFS的详细完成

DFS重要采纳递归完成,顺次遍历节点,假如遍历到的节点有子节点,则最先遍历子节点

const DFSTraverse = (rootNodes, rootLayer) => {
const roots = Array.from(rootNodes)
while (roots.length) {
const root = roots.shift()
printInfo(root, rootLayer)
// 假如有子节点,直接遍历子节点,同时将层级加1
if (root.children.length) {
DFSTraverse(root.children, rootLayer + 1)
}
}
}

BFS的详细完成

BFS采纳行列的头脑,采纳出队的体式格局遍历节点,假如遍历到的节点有子节点,则将子节点入队(这里处置惩罚节点层级的体式格局比DFS更庞杂一些,由于这里将一切节点都放到了同一个数组中举行处置惩罚)

const BFSTraverse = (rootNodes, rootLayer) => {
const roots = Array.from(rootNodes)
const rootsLayer = [] // 单用一个数组寄存每一个节点的的层级
// 初始化
for (let i = 0; i rootsLayer.push(rootLayer)
}
var rootIdx = 0 // 纪录当前处置惩罚roots中的第几个节点,轻易查找rootsLayer中对应的层级
while (roots.length) {
const root = roots.shift() // 出队
printInfo(root, rootsLayer[rootIdx])
// 假如有子节点,将子节点放到roots行列中
if (root.children.length) {
Array.prototype.push.apply(roots, Array.from(root.children))
// 将当前层级加1获得子节点的层级
rootLayer = rootsLayer[rootIdx] + 1
for (let i = 0; i rootsLayer.push(rootLayer)
}
}
// 处置惩罚下一个root节点
rootIdx++
}
}

效果

先给人人补全代码:

// 输入节点信息
const printInfo = (node, layer) => {
var str = ''
for (let i = 1; i str += ' '
}
console.log(`${layer}:${str}${node.tagName} .${node.className}`);
}
console.log('DFS *******************************');
DFSTraverse(document.querySelectorAll('.root'), 1);
console.log('BFS *******************************');
BFSTraverse(document.querySelectorAll('.root'), 1);

上面例子的运转效果为:
《DOM树遍历之JS完成DFS&BFS》

参考

破解前端口试(80% 应聘者不及格系列):从 DOM 提及
Javascript-ONLY DOM Tree Traversal – DFS and BFS?


推荐阅读
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文讨论了在Spring 3.1中,数据源未能自动连接到@Configuration类的错误原因,并提供了解决方法。作者发现了错误的原因,并在代码中手动定义了PersistenceAnnotationBeanPostProcessor。作者删除了该定义后,问题得到解决。此外,作者还指出了默认的PersistenceAnnotationBeanPostProcessor的注册方式,并提供了自定义该bean定义的方法。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • WebSocket与Socket.io的理解
    WebSocketprotocol是HTML5一种新的协议。它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
author-avatar
狂风
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有