From cc978074d54122837d1b0a9de0a885bd9a87a010 Mon Sep 17 00:00:00 2001 From: YuJian920 Date: Sun, 8 May 2022 16:58:09 +0800 Subject: [PATCH] vault backup: 2022-05-08 16:58:09 --- .../React 的流程解析 - Fiber 递归.md | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md b/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md index 7a40d0c..8abf822 100644 --- a/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md +++ b/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md @@ -6,7 +6,15 @@ ## React 17 -Fiber 递归开始首先会交由 createWorkInProgress 函数生成 WorkInProgress 的第一个 Fiber 节点,这个节点就是 FiberNode,所以我们也从 createWorkInProgress 函数开始讲解 React 中 Fiber 递归的流程,**这个函数的主要工作就是根据传入的 Fiber 节点的判断复用 Fiber 节点还是创建新的 Fiber 节点**,而这个判断的条件就是传入的 Fiber 节点的 alternate 属性是否存在,在首屏渲染中具体的函数深入解析可以看 [[React 的深入探索 - createWorkInProgress]]。 +Fiber 递归开始首先会交由 createWorkInProgress 函数生成 WorkInProgress 的第一个 Fiber 节点,这个节点就是 FiberNode,所以我们也从 createWorkInProgress 函数开始讲解 React 中 Fiber 递归的流程,**这个函数的主要工作就是根据传入的 Fiber 节点的判断复用 Fiber 节点还是创建新的 Fiber 节点**,而这个判断的条件就是传入的 Fiber 节点的 alternate 属性是否存在,在第一次进入到这个函数时也就是首屏渲染中传入的 FiberNode 是不存在这个属性的,所以会进入到 createFiber 函数:即执行创建新 Fiber 节点的逻辑 + +```javascript +function createWorkInProgress(current, pendingProps) { + +} +``` + +这个函数具体的深入解析可以看 [[React 的深入探索 - createWorkInProgress]]。 第一次 createWorkInProgress 执行完毕之后,接下来就会交给 beginWork 开始正式的 Fiber 递归,在 React 中 Fiber 的创建使用递归实现的深度优先遍历算法,即尽可能深的探索树的分支,探索完毕后再回溯,在这一过程中负责探索阶段的就是 beginWork 函数。