React源码 - 初始化元素

版本:17.0.0
创建调试项目可以下载此项目 - 地址 (https://github.com/mzvast/debug-react-ts)

一. 从React项目初始加载项目源码分析,分析如下代码在 React中的执行过程
在这里插入图片描述
从 ReactDOM的 render 方法开始调试
在这里插入图片描述
下图中主要创建了一个 FiberRootNode 对象,包含 containerInfo(挂载的元素), current对象(RootFiber )
在这里插入图片描述
此图中为 FiberRoot 中添加 current 值的代码
在这里插入图片描述
此图中为 RootFiber 添加 queue 的代码
在这里插入图片描述
更新方法 unbatchedUpdates 调用 传入函数中的方法 updateContainer,updateContainer方法创建了一个更新 update
在这里插入图片描述
下图中的enqueueUpdate方法将 update 值 附加到 RootFiber 的 updateQueue.shared.pending对象中
在这里插入图片描述
scheduleUpdateOnFiber => performSyncWorkOnRoot => renderRootSync(根据 ReactDOM.render传入的children为起点构建 Fiber 和 alternate )
--------------------------------------------------------------------------------renderRootSync函数执行之后 commitRoot (更新 dom 树)

renderRootSync => prepareFreshStack => createWorkInProgress
下图中的方法复制了 RootFiber ,并赋值给了 RootFiber.alternate
在这里插入图片描述

在这里插入图片描述

renderRootSync => workLoopSync => performUnitOfWork
在这里插入图片描述
一直循环 workInProgress ,next 为 begin 函数的返回值,next 为 null 时这个节点遍历完成,执行 completeUnitOfWork
在这里插入图片描述
beginWork 根据 tag 创建 Fiber 元素 => updateHostRoot
在这里插入图片描述
updateHostRoot => cloneUpdateQueue 克隆了 workInProgress.updateQueue, 目的是不再和 RootFiber (current) 引用同一个对象,更改 workInProgress.updateQueue 时 RootFiber (current) 的 updateQueue 不会改变
在这里插入图片描述
在这里插入图片描述
updateHostRoot => processUpdateQueue
processUpdateQueue 函数
1.将RootFiber (current).updateQueue.shared.pending中的 update赋值到了 updateQueue.firstBaseUpdate,updateQueue.lastBaseUpdate,并清空了 pending的值
在这里插入图片描述

2.workInProgress(alternate).updateQueue.shared.pending中的 update 赋值到了 updateQueue.baseState 和 memoizedState,并清空了 pending的值
在这里插入图片描述
updateHostRoot => reconcileChildren => reconcileChildFibers
根据传入的 children 创建 Fiber, 并将值添加到 workInProgress.child上
在这里插入图片描述
reconcileChildFibers
根据不同的节点类型
1.如果此元素有子元素,则根据子元素为单个的情况创建Fiber, 并将 return 字段指向父元素,为多个的情况则遍历子元素,通过sibling字段连接子元素,将第一个子元素为父元素的子元素
2.如何没有子节点, 则 workInProgress.child 值为空,执行上述提到的 更新 dom 的 方法 commitRoot
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 学习 React 源码是一项很有益的学习活动,可以帮助你加深对 React 的理解,并且为你提供有关如何实现组件化和声明式编程的知识。 在学习 React 源码时,我有几个建议: 1. 先从官方文档入手,了解 React 的基本概念和使用方法。这将有助于你更好地理解 React 源码。 2. 认真阅读源码注释。React源码非常详细,并且有很多注释,这些注释很有帮助,可以帮助你理解源码的目的和工作原理。 3. 使用调试工具,以帮助你更好地理解源码的工作流程。比如,可以使用浏览器的开发者工具调试 React 代码,或者使用断点调试。 4. 尝试实现一些自己的功能,并结合源码来调试和理解。这将有助于你更好地理解 React 的工作原理,并且能够让你在实际使用中更加熟练。 5. 可以尝试加入 React 开源社区,与其他 React 开发者交流经验,也可以参与 React 的开源项目,为 React 贡献代码。这将有助于你不断学习和提升。 ### 回答2: 学习React源码是一个非常有挑战性但也非常有价值的任务。首先,我建议你先熟悉React的基本概念和使用方法,理解React的核心思想和设计理念,然后再深入研究源码。以下是一些具体的建议: 1. 掌握JavaScript和ES6的基础知识:React源码是用JavaScript编写的,因此对于JavaScript的理解是必要的。确保你对JavaScript中ES6的新特性例如模块导入导出、箭头函数、解构赋值等有一定的了解。 2. 阅读官方文档和源码注释:React官方提供了非常详细的文档和源码注释,阅读它们可以帮助你快速了解React的内部工作原理和实现细节。 3. 从顶层开始分析:从React的顶层入手,逐步深入源码。首先阅读React的入口文件,了解React是如何初始化和渲染组件的。然后再深入了解React组件的生命周期和更新机制。 4. 使用工具进行调试:使用Chrome DevTools等工具进行调试可以帮助你更好地理解和分析React的运行时行为。通过在源码中设置断点并观察变量的值,可以深入理解React的执行流程。 5. 理解虚拟DOM和协调算法:React的核心是虚拟DOM和协调算法,学习和理解它们对于深入理解React源码非常重要。阅读相关的源码实现,将有助于你理解React如何高效地更新DOM。 6. 参考社区资源和开源项目:React有一个非常庞大的社区,许多优秀的开源项目可以帮助你更好地理解React源码。与其他人一起学习和讨论,参与到React相关的开源项目中,将加快你的学习进度。 总结起来,学习React源码需要坚实的JavaScript基础和对React的理解。通过仔细阅读官方文档、源码注释和调试工具的使用,以及参考社区资源和开源项目,你将能够逐渐深入了解React的实现细节,提高自己的技术水平。 ### 回答3: 学习React源码的过程可以相当艰巨,但也是丰富而值得的。以下是几些建议帮助你更好地学习React源码: 1. 先理解React的核心概念:在深入研究源码前,先确保你对React的基本理念和工作方式有了清晰的理解。了解虚拟DOM、组件生命周期、状态管理和数据流等核心概念将有助于更好地理解源码。 2. 创建一个简单的React应用:在学习React源码时,建议你尝试创建一个简单的React应用并深入研究它的实现细节。这样可以帮助你更好地理解React的工作原理和内部机制。 3. 阅读React官方文档和源码注释:React源码中有丰富的注释,它们会对源码的实现细节进行解释和说明。同时,React官方文档也提供了很多有价值的内容,包括API文档和设计原则。阅读这些内容能够帮助你更好地理解React的思想和设计理念。 4. 利用调试工具:学习源码的过程中,调试工具是非常有用的辅助资源。使用断点和调试器来观察源码的执行路径和状态变化,可以帮助你更好地理解代码的运行机制。 5. 参考优秀的源码解析和开源项目:很多开发者在学习React源码后,会产生一些优秀的博客文章、视频教程和开源项目,其中包含了他们对源码的解析和实践。阅读这些资源可以帮助你更好地理解React源码并从中获取灵感。 学习React源码需要耐心和持续努力,希望以上建议能够帮助你更好地进行这个过程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值