React 执行架构流程详细----归阶段 mount 时流程(三)
创始人
2025-05-30 10:41:40
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

相关内容

热门资讯

css单位px,rem,em,... pxpx就是pixel像素的缩写,相对长度单位,网页设计常用的基本单位。...
【独家】华为OD机试 - 删除... 最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真...
2025韩系车太委屈!全球第4... 2025年韩系车,真的“寒”前两日,小编为大家分享了一下,2025年度美系车在中国汽车市场艰难的表现...
【C++】面向对象之继承 谈到面向对象的三大特性,必然绕不开封装、继承和多态。 但是需要明确的是三大特性是所有的...
【 Deep-Shallow ... A Deep-Shallow Fusion Network with Multi-Detail Ex...
机器学习必知的基础概念(Fun... 机器学习必知的基础概念(Fundamental Theories of Machine...
Word怎么转换成PDF文件格... PDF是一种通用的文件格式,它可以在不同操作系统和设备上保持一致的显示效果。在日常工作...
【C++】面试101,二叉搜索... 目录 1.二叉搜索树的最近公共祖先  2.在二叉树中找到两个节点的最近公共祖先 3.序列化二叉树 4...
linux简单入门 目录Linux简介Linux目录结构Linux文件命令文件处理命令文件查看命令常用文件查看命令Lin...
LP周报丨央企创投母基金来了,... 一级市场再现重量级玩家。本周,由国务院国资委指导、中国诚通控股集团有限公司牵头组建的“诚通科创投资基...
估值600多亿,马斯克的超级独... 刚宣布回归全天候工作没多久,马斯克便给旗下公司融了一笔钱。几天前,马斯克创立的脑机接口公司Neura...
Python3 入门教程||P... Python3 数据结构本章节我们主要结合前面所学的知识点来介绍 Python 数据结构。列表Pyt...
0110 Tomcat 1.JavaWeb 所有通过Java语言编写可以通过浏览器访问的程序的总称叫JavaWebÿ...
C++ Primer第五版_第... 文章目录练习4.1练习4.2练习4.3练习4.4练习4.5练习4.6练习4.7练习4.8练习4.9练...
LuaJIT 栈帧布局(sta... 对于任何的目标架构(如x86、arm、loongarch),...
【必看】最全开窗函数讲解和实战... 窗口函数(Window Function)是 SQL2003 标准中定义...
PyTorch入门(六)使用T...   在文章PyTorch入门(五)使用CNN模型进行中文文本分类中&#x...
app自动化测试——特殊控件T... 文章目录一、Toast弹窗是什么二、Toast 定位方式一:方式二三、案例1、特别注意...
零基础入门学习Python 0... 目录 1.递归 2.异常处理 1.递归 啥是递归 相当于函数调用自身对栈操作频繁,...
云原生周刊:12 个容易忽略的... 文章推荐 12 个容易忽略的 Kubernetes 安装错误 这篇文章总结了 12 个在 Kuber...