什么是虚拟dom,说一下react和vue的diff算法
创始人
2024-03-07 09:14:06
0

什么是虚拟dom

组件第一次渲染的时候会生成一个虚拟dom和一个真实的dom然会会把真实的dom渲染到页面上
如果这个组件受到响应式数据变化的影响,需要重新渲染时,它仍然会重新调用render函数,创建一个新的虚拟dom树,这时会用新虚拟dom树(newVnode)和旧虚拟dom树(oldVnode)进行对比,通过比对,找到最小更新量,然后更新必要的虚拟dom节点,最后,这些更新过的虚拟节点会去修改它们对应的真实dom。这样一来就保证了对真实dom的操作达到了最小的改动。


react的diff算法

遵行三个原则:1.树的比较(tree diff)2.组建的比较(component diff)3.元素的比较(element diff)

1.树的比较
react会对比虚拟dom树和真实的dom树,对比他们的同一层级,对比时如果存在虚拟dom没有的节点而真是dom有就会删除这个节点,如果虚拟dom有真是dom没有就会创建这个节点,此过程只有只有删除和创建操作

注意:
但是如果DOM节点出现了跨层级操作,diff会如何处理?
就是A节点下面的b节点移动到了D的节点下,这时react会删除A节点下的b节点然后再D节点下创建b节点


2.组件的比较
如果是同一个类的组件,则会继续往下diff运算,如果不是一个类的组件,那么直接删除这个组件下的所有子节点,创建新的


3.元素的比较

如果存在key的话react就会对比key一样的新旧集合,没有的话只能按顺序比较,这也是为什么加key能够优化性能,如果存在一个列表,把第一个li移动到最后一个li下面,如果不存在key后续li都会更新存在key的话只要把第一个移动到最后就行,其他节点都不会更新

react会记录旧集合的索引,比如交oldindex,来回记录一个索引,他代表再就集合中已经对比过的元素在旧集合中最大的索引,比如叫maxindex,他们有一个移动规则,当oldIndex>maxIndex时,将oldIndex的值赋值给maxIndex,当oldIndex=maxIndex时,不操作,当oldIndex


详细的看:
https://vue3js.cn/interview/React/diff.html#%E4%B8%89%E3%80%81%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9

https://blog.csdn.net/qq_36407875/article/details/84965311

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...