【React】Diff算法

本文详细解析了React15的Diff算法,涉及树比较、组件比较和元素比较,以及React16+的FiberReconciler中的异步可中断Diff过程,包括单节点和多节点比较,以及Fiber的创建、删除和更新操作。
摘要由CSDN通过智能技术生成
1. React15 Diff算法(递归进行)

一句话概括:新虚拟DOM和旧虚拟DOM对比,找出差异,根据差异更新真实DOM
Diff过程描述:
1. 树比较(DOM)
同层节点之间相互比较,不会跨层级比较。(当发现节点不存在了,则将该节点及其⼦节点全部删除)
2. 组件比较(class组件)
不同类型的节点,产生不同的树结构。(节点的类型相同,则按原策略继续比较虚拟DOM,节点的类型不同,移除老节点,创建新节点)
3. 元素比较(DOM)
同一层级子节点,可以通过 key 来指定那些节点在不同的渲染下保持稳定

2. React16+ Diff算法(Fiber Reconciler,异步可中断)

一句话概括:React17 Diff算法是新JSX对象跟老Fiber树的对比,生成新Fiber的过程
Diff过程描述:
1. 单节点比较:如果新的子节点(JSX)只有一个元素的话,对应老Fiber是一个或者多个。
1.1 key相同,type相同,复用老Fiber,将老Fiber节点标记为更新;
1.2 key相同,type不同,老Fiber标记删除,根据新的JSX生成新的Fiber,并标记插入;
1.3 key不同,将当前老Fiber标记删除,继续与老Fiber节点的其他兄弟Fiber进行比较。
2. 多节点比较:如果JSX对象是一个数组的话
第一轮遍历(依次比较):
2.1 依次比较,key和type都相同,全部可复用
2.2 遇到key相同,type不同,不可复用,则将相应老Fiber节点标记删除,根据JSX生成新的Fiber节点
2.3 遇到key不同,直接进入第二轮遍历
2.4 如果JSX对象遍历结束,或者老Fiber遍历结束,进入第二轮遍历
第二轮遍历(分四种情况)
2.5 JSX对象和老Fiber都遍历完了,第二轮遍历直接结束
2.6 JSX对象遍历完了,老Fiber没有遍历完,将剩下老Fiber节点标记删除
2.7 JSX对象没有遍历完,老Fiber遍历完了,根据剩下JSX中元素创建新Fiber,并标记插入
2.8 JSX对象和老Fiber都没有遍历完,根据JSX对象中元素的顺序,对老Fiber进行移动。

所有标记effectTag的Fiber节点形成一条单向链表,在commit阶段,遍历该单向链表,根据effectTag更新真实DOM
 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React diff算法React用来在虚拟DOM树中找到变化并更新实际DOM的一种算法。它的原理是通过比较新旧虚拟DOM树的差异,然后只更新真正发生变化的部分,而不是直接重新渲染整个页面。 React diff算法的高阶原理是通过三个步骤来进行差异比较: 1. 树的遍历:首先,React会对新旧两棵虚拟DOM树进行深度优先遍历,找出所有的节点并进行标记。 2. 节点的比较:在遍历过程中,React比较新旧两个节点的类型(标签名)和属性。如果类型相同且属性相同,则认为这个节点是相同的,不需要更新。如果类型不同,则直接替换该节点。如果类型相同但属性不同,则更新该节点的属性。 3. 子节点的递归比较:如果两个节点相同,并且有子节点,则会对子节点进行递归比较React会对子节点列表进行遍历,并在新旧子节点列表中找出相同的节点进行比较。如果找到了相同的节点,则继续递归比较其子节点。如果没有找到相同的节点,则说明这是一个新增或者删除的节点,需要进行相应的操作。 通过这种方式,React diff算法可以高效地找到变化的节点并进行更新,避免了无谓的重复渲染,提升了性能。但是需要注意的是,React diff算法并不是完全精确的,有时候可能会出现误判或者不够高效的情况,所以在开发中还需要注意一些优化策略,例如使用key属性来帮助React更准确地识别节点的变化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值