From 23eb76c1f3a708cf212585dce95204609c2da28f Mon Sep 17 00:00:00 2001 From: YuJian Date: Mon, 9 May 2022 10:31:43 +0800 Subject: [PATCH] vault backup: 2022-05-09 10:31:43 --- .../React 的流程解析 - Fiber 递归.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md b/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md index 9bf5f3e..b22fc4c 100644 --- a/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md +++ b/React 的源码深入/React 的流程解析 - Fiber 递归/React 的流程解析 - Fiber 递归.md @@ -9,6 +9,7 @@ Fiber 递归开始首先会交由 createWorkInProgress 函数生成 WorkInProgre 2. 当前 Fiber 节点属性新增的节点 如果判断 alternate 不存在,会进入到 createFiber 函数:即执行创建新 Fiber 节点的逻辑。 +否则就会进行 Fiber 复用。 ```javascript function createWorkInProgress(current, pendingProps) { @@ -38,7 +39,7 @@ function createWorkInProgress(current, pendingProps) { 这个函数具体的深入解析可以看 [[React 的深入探索 - createWorkInProgress]]。 -createWorkInProgress 执行完毕之后,我们就有了一个 WorkInProgress Fiber 节点,接下来就会交给 beginWork 开始正式的 Fiber 递归,在之后的 beginWork 流程中,如果发现存在新增的 Fiber 节点,也会进入到 createWorkInProgress 这个函数逻辑中。 +createWorkInProgress 执行完毕之后,我们就有了一个 WorkInProgress Fiber 节点,接下来就会交给 beginWork 和 completeWork 开始正式的 Fiber 递归,在之后的 beginWork 流程中,如果发现存在新增的 Fiber 节点,也会进入到 createWorkInProgress 这个函数逻辑中。 在 React 中 Fiber 的创建使用递归实现的深度优先遍历算法,即尽可能深的探索树的分支,探索完毕后再回溯,在这一过程中负责探索阶段的就是 beginWork 函数。