[vue.js设计和实现]简单的Dom Diff算法

简介: [vue.js设计和实现]简单的Dom Diff算法

今天翻看了vue.js设计和实现的第九章内容,主要是谈论Dom的Diff算法。因为实际操作dom的开销很大,所以有dom的Diff算法来减小操作dom的次数,来提高性能。


一.比较标签元素



通过比较标签的元素,来减少操作dom的次数。只要新旧子节点中的标签相同,我们就只更新节点的内容就可以


二.新旧子节点的数量不同



第一点中,我们默认了新旧子节点的数量是一样的,但是实际中我们可以要卸载或挂载上节点。这时候我们应该比较新旧节点的数量,遍历数量少的那一组节点,然后再判断剩余节点是应该挂载上还是卸载掉


三.Dom复用和key



如果新旧子节点的标签相同,只是顺序不一样。难道我们还应该在全部卸载再挂载上去吗?其实我们只需要移动节点的顺序,便可达到同样的效果。但是移动的前提是我们必须找到可以复用的子节点,所以我们要进行一轮对比操作,判断旧的子节点中有没有可以复用的。假如我们还是通过标签的方式来进行判断,若新旧子节点中的标签是一样的,那么我们无法知道这个新节点中的标签对应到旧节点中的标签是哪一个,也就无法得知我们应该如何移动,所以我们引入了key,只要两个虚拟节点的 type 属性值和 key 属性值都相同,那么我们就认为它们是相同的,即可以 进行 DOM 的复用。


四.如何移动



1.找到需要移动的元素


逆向思维,什么时候不需要移动元素。当新旧子节点的顺序相对不变的时候,我们便不需要移动元素。使用lastIndex记录新节点在旧节点中的最大索引值,如果索引值递增的顺序被打破,则需要移动该元素。


2.如何移动


通过改变引用的方式


image.png

改变引用后


image.png


添加新元素


如果有前一个 vnode 节点,则使用它的下一个兄弟节点作为锚点元素,如果没有前一个 vnode 节点,说明即将挂载的新节点是第一个子节。


删除元素


当基本的更新结束时,我们需要遍历旧的一组子节点,然后去新的一组子节 点中寻找具有相同 key 值的节点。如果找不到,则说明应该删除该节 点


目录
相关文章
|
4月前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
|
4天前
|
运维 监控 JavaScript
内网网管软件中基于 Node.js 的深度优先搜索算法剖析
内网网管软件在企业网络中不可或缺,涵盖设备管理、流量监控和安全防护。本文基于Node.js实现深度优先搜索(DFS)算法,解析其在网络拓扑遍历中的应用。通过DFS,可高效获取内网设备连接关系,助力故障排查与网络规划。代码示例展示了图结构的构建及DFS的具体实现,为内网管理提供技术支持。
28 11
|
1天前
|
监控 网络协议 算法
基于问题“如何监控局域网内的电脑”——Node.js 的 ARP 扫描算法实现局域网内计算机监控的技术探究
在网络管理与安全领域,监控局域网内计算机至关重要。本文探讨基于Node.js的ARP扫描算法,通过获取IP和MAC地址实现有效监控。使用`arp`库安装(`npm install arp`)并编写代码,可定期扫描并对比设备列表,判断设备上线和下线状态。此技术适用于企业网络管理和家庭网络安全防护,未来有望进一步提升效率与准确性。
19 8
|
1月前
|
JavaScript 算法 安全
深度剖析:共享文件怎么设置密码和权限的 Node.js 进阶算法
在数字化时代,共享文件的安全性至关重要。本文聚焦Node.js环境,介绍如何通过JavaScript对象字面量构建数据结构管理文件安全信息,包括使用`bcryptjs`库加密密码和权限校验算法,确保高效且安全的文件共享。通过实例代码展示加密与权限验证过程,帮助各行业实现严格的信息资产管理与协作。
|
1月前
|
存储 监控 算法
局域网网络管控里 Node.js 红黑树算法的绝妙运用
在数字化办公中,局域网网络管控至关重要。红黑树作为一种自平衡二叉搜索树,凭借其高效的数据管理和平衡机制,在局域网设备状态管理中大放异彩。通过Node.js实现红黑树算法,可快速插入、查找和更新设备信息(如IP地址、带宽等),确保网络管理员实时监控和优化网络资源,提升局域网的稳定性和安全性。未来,随着技术融合,红黑树将在网络管控中持续进化,助力构建高效、安全的局域网络生态。
52 9
|
2月前
|
监控 算法 JavaScript
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
55 7
|
1月前
|
存储 监控 JavaScript
深度探秘:运用 Node.js 哈希表算法剖析员工工作时间玩游戏现象
在现代企业运营中,确保员工工作时间高效专注至关重要。为应对员工工作时间玩游戏的问题,本文聚焦Node.js环境下的哈希表算法,展示其如何通过快速查找和高效记录员工游戏行为,帮助企业精准监测与分析,遏制此类现象。哈希表以IP地址等为键,存储游戏网址、时长等信息,结合冲突处理与动态更新机制,确保数据完整性和时效性,助力企业管理层优化工作效率。
35 3
|
3月前
|
JavaScript 前端开发 索引
js中DOM的基础方法
【10月更文挑战第31天】这些DOM基础方法是操作网页文档结构和实现交互效果的重要工具,通过它们可以动态地改变页面的内容、样式和行为,为用户提供丰富的交互体验。
|
3月前
|
JavaScript 前端开发 开发者
.js的dom元素操作
【10月更文挑战第29天】通过灵活运用这些 DOM 元素操作方法,JavaScript 可以实现丰富的网页交互效果,如动态更新页面内容、响应用户操作、创建和删除页面元素等。在实际开发中,开发者可以根据具体的需求和场景,选择合适的 DOM 元素操作方法来实现所需的功能,为用户提供更加流畅和动态的网页体验。
|
4月前
|
算法 JavaScript UED
Diff 算法的实现原理
【10月更文挑战第18天】Diff 算法是 Vue.js 中实现高效 DOM 更新的核心机制,通过合理的比较和优化策略,能够在保证界面正确性的同时,最大程度地减少 DOM 操作,提高应用的性能和用户体验。
77 2

热门文章

最新文章