React 执行架构流程详细----归阶段 mount 时流程(三)
创始人
2025-05-30 10:18:47
0

React 执行架构流程详细----归阶段 mount 时流程(三)

目录

    • React 执行架构流程详细----归阶段 mount 时流程(三)
      • 引言
        • 归阶段 mount 时流程
        • 🌰
      • 总结
      • 解决问题
        • 问题提出
        • 解答


引言

由前一篇可知:

  • render 阶段就是采用dfs的方式依次执行fiber节点的 beginWork 和 completeWork

  • 整个 React 执行分为四个阶段,今天阐述第二个阶段:归阶段 mount 时流程


归阶段 mount 时流程

也就是 mount 阶段 completeWork 的流程

🌰

  1. 对于以下这个结构来说:
    在这里插入图片描述
  2. 第一个进入 completework 的节点是 img ,会根据 fiber节点的 type 进入不同的 case
    在这里插入图片描述
    img 节点是 host component ,所以进入这个case:
    在这里插入图片描述
  3. 首先会判断 current 是否存在,首次渲染时 current 是不存在的,接下来会为 hostcomponent 对应的 fiber 节点创建对应的 DOM 节点,进入 createInstance 函数:
    在这里插入图片描述
  4. 可以看到 在 createInstance 中执行了 createElement 函数,domElement 就是 img DOM 元素
    在这里插入图片描述
  5. 当创建完dom 节点后,会通过 appendAllChildren 函数 将这个节点插入到到之前已经创建好的dom树中。
    appendAllChildren 的作用:将已经创建好的dom节点挂载到当前dom 树下,当我们 归阶段,从每一个子节点一路向上,归到根节点时,创建的每一个子节点都会挂载到它的父级dom节点下,当执行到 App 节点时,就已经有一棵构建好的 dom 树
    在这里插入图片描述
  6. 接下来会将 img dom 节点保存在 img 对应的 fiber 节点的 stateNode 属性上
    在这里插入图片描述
  7. 最后在 finalizeInitialChildren 给 dom 节点设置一些属性,img 节点上加上了 alt,className 等属性
    在这里插入图片描述
  8. 进入 setInitialProperties 函数:
    在这里插入图片描述
    首先会判断这是否是一个自定义标签,接下来会根据 hostcomponent 的 tag 来进入不同的逻辑

    再判断props 是否合法,再进入初始化 dom 属性的操作

    属性类型不同做不同的处理
    在这里插入图片描述
    最终会调用 setAttribute 进行属性赋值:
    在这里插入图片描述

即一个 fiber 节点的 completework 就完成了,之后就进入下一个 fiber 节点的 completework

PS:对于以下类型的组件,是没有 completeWork 的逻辑的
在这里插入图片描述


总结

  1. 会判断当前fiber节点的类型,进入不同的 case(比如说是 HostComponent,就进入相关的 case)
  2. 首先会判断 current 是否存在
  3. 为 HostComponent 对应的 fiber 节点创建对应 的 DOM 节点,会将这个DOM节点保存在 该fiber 的 stateNode 上,然后再为DOM 节点设置一些属性(初始化属性)
  4. 将创建好的节点插入到 DOM 树中:每一个 hostComponent 在 appendChildren 函数中,执行挂载
  5. 然后就进入下一个 fiber 节点的 completeWork 的过程
  6. 当整个应用的所有节点都执行完了 completeWork 时,将 root node 的标记 effectTag 置为 placement,就能将整棵 树进行挂载到页面上

解决问题

问题提出

在 reconcileChildren 中,当某个 fiber 节点不存在对应的 current 节点时,他是不会被标记 effectTag 的,那么首屏渲染的时候,这些 DOM 节点是如何挂载到页面中的呢?

解答

对于首屏渲染,会有一个节点进入 reconcileChildFibers 逻辑,这个存在 current 节点的就是当前应用的根节点,即下图中的 FiberRootNode

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

之后会进入 reconcileSingleElement 函数:
在这里插入图片描述

进入 placeSingleChild :App 节点的effectTag会被赋值为 placement

只需要在App这一级有一个 Placement 的 effectTag ,就能将整棵 dom树挂载到页面上,这就是首屏渲染的 dom插入逻辑

在这里插入图片描述


参考资料:
React 项目源码
技术揭秘
React 版本是17

相关内容

热门资讯

安卓系统怎么关钥匙,轻松掌握钥... 手机里的安卓系统,是不是有时候让你觉得有点儿头疼?比如,当你想关掉手机,却发现钥匙在哪里呢?别急,今...
安卓系统有隐私空间,打造安全私... 你知道吗?在智能手机的世界里,安卓系统可是个超级明星呢!它不仅功能强大,而且现在还悄悄地给你准备了一...
安卓系统设置角标,打造专属通知... 你有没有发现,手机上的安卓系统设置里有个神奇的小功能——角标?这个小东西虽然不起眼,但作用可大了去了...
安卓系统定位信息查询,揭秘移动... 你有没有想过,你的手机里藏着多少秘密?尤其是那个安卓系统,它可是个超级侦探,随时随地都在帮你定位。今...
安卓刷入系统恢复,轻松实现设备... 手机系统崩溃了?别慌!安卓刷入系统恢复大法来啦! 手机,这个我们生活中不可或缺的小伙伴,有时候也会闹...
安卓系统限制无法录音,探索无法... 你有没有遇到过这种情况?手机里明明装了录音软件,却突然发现,哎呀妈呀,竟然无法录音了!这可真是让人头...
怎么降级手机系统安卓,操作指南... 手机系统升级了,新功能层出不穷,但有时候,你可能会觉得,这系统太卡了,想回到那个流畅如丝的年代。别急...
米oa系统是安卓系统吗,深入解... 亲爱的读者,你是否曾好奇过,米OA系统是不是安卓系统的一员?这个问题,就像是一颗好奇的种子,悄悄地在...
手机刷安卓车载系统,手机刷机后... 你有没有发现,现在开车的时候,手机和车载系统之间的互动越来越紧密了呢?想象当你驾驶着爱车,一边享受着...
vivo安卓怎么降系统,viv... 手机用久了,是不是觉得系统越来越卡,运行速度大不如前?别急,今天就来教你怎么给vivo安卓手机降降级...
nova 4刷安卓系统,体验全... 最近手机界可是热闹非凡呢!听说华为nova 4要刷安卓系统了,这可真是让人兴奋不已。你有没有想过,你...
如果当初没有安卓系统,科技世界... 想象如果没有安卓系统,我们的生活会是怎样的呢?是不是觉得有点不可思议?别急,让我们一起穿越时空,探索...
安卓电视装win系统,系统转换... 亲爱的读者们,你是否曾想过,在你的安卓电视上装一个Windows系统,让它瞬间变身成为一台功能强大的...
安卓手机还原系统好处,重拾流畅... 你有没有遇到过安卓手机卡顿、运行缓慢的情况?别急,今天就来给你揭秘一下安卓手机还原系统的那些好处,让...
安卓系统能跑win吗,探索跨平... 你有没有想过,你的安卓手机里能不能装上Windows系统呢?这听起来是不是有点像科幻电影里的情节?别...
安卓车载系统蓝牙设置,畅享智能... 你有没有发现,现在开车的时候,手机和车载系统之间的互动越来越频繁了呢?这不,今天就来给你详细说说安卓...
奥利奥安卓系统,探索新一代智能... 你有没有想过,一块小小的奥利奥饼干竟然能和强大的安卓系统扯上关系?没错,今天就要来聊聊这个跨界组合,...
微信使用安卓系统,功能解析与操... 你有没有发现,现在用微信的人越来越多了呢?尤其是安卓系统的用户,简直就像潮水一样涌来。今天,就让我带...
体验最新原生安卓系统,极致体验... 你有没有想过,手机系统就像是我们生活的调味品,有时候换一种口味,生活都会变得有趣起来呢?最近,我体验...
安卓系统能玩原神,尽享奇幻冒险... 你有没有想过,在安卓系统上也能畅玩《原神》这样的热门游戏呢?没错,就是那个画面精美、角色丰富、玩法多...