首先值得注意的是,第一次渲染的时候,调用的是 renderRootSync
即同步模式,其他的情况可能会调用 renderRootConcurrent
即并发模式。
-
prepareFreshStack
开始执行时,workInProgressRoot
尚未初始化,还是 null,在prepareFreshStack
中对workInProgressRoot
进行了初始化为当前尚未渲染的FiberRootNode
,并额外 初始化了workInProgressXxx
。此时整个 fiber tree 都尚未开始初始化,顶部的结构如下。
data:image/s3,"s3://crabby-images/70b17/70b17fc6f304313e28328d7fe2e78a6a69e2c04c" alt=""
-
workLoopSync
这是生成 fiber tree 的主循环
// The work loop is an extremely hot path. Tell Closure not to inline it.
/** @noinline */
function workLoopSync() {
// Perform work without checking if we need to yield between fiber.
if (workInProgressIsSuspended && workInProgress !== null) {
// The current work-in-progress was already attempted. We need to unwind
// it before we continue the normal work loop.
resumeSuspendedUnitOfWork(workInProgress);
}
while (workInProgress !== null) {
performUnitOfWork(workInProgress);
}
}
网友评论