From 89e438d2422d0203115ad687569172e911292929 Mon Sep 17 00:00:00 2001 From: YuJian920 Date: Sat, 16 Apr 2022 10:24:44 +0800 Subject: [PATCH] vault backup: 2022-04-16 10:24:44 --- React 的源码深入/React Reconciler - Fiber 创建.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/React 的源码深入/React Reconciler - Fiber 创建.md b/React 的源码深入/React Reconciler - Fiber 创建.md index 368ee78..2801204 100644 --- a/React 的源码深入/React Reconciler - Fiber 创建.md +++ b/React 的源码深入/React Reconciler - Fiber 创建.md @@ -5,7 +5,8 @@ 在 React 中,视图的更新使用了双缓存的方式,也就是说在 React 运行时,同时有着两棵 Fiber 树,一颗是当前视图上的 Fiber 树,叫 current,另外一棵是存在内存当中的下一次视图更新时用的叫做 workInProgress,React 在构建时会创建整个 app 唯一的根 Fiber 节点,叫做 FiberRootNode,这个节点上有一个 current 指针,指向的是当前正在页面上显示的 Fiber 树也就是 current,当 workInProgress 递归生成完毕,指针会立即指向 workInProgress ,而旧的 current 就会在下一次渲染中变成 workInProgress ,就这样循环交替完成页面的递归渲染 ## 首屏渲染 -React 的首屏渲染时会交由 createW +React 的首屏渲染时会交由 createWorkInProgress 函数生成一棵 WorkInProgress Fiber 树,createWorkInProgress 接收两个参数,分别是 current 和 pendingProps,这里的 pendingProps 是组件的属性 +因为传入的是 current Fiber 树,所以 createWorkInProgress 内会从 current 的 alternate 取出中取出 ### 第一次触发更新