react06-jsx渲染机制

react06-jsx渲染机制

react.createElemnet() ==》 构建虚拟dom

构建视图的具体流程 :

  • 将jsx语法,编译为虚拟dom对象 ,根据react中的处理生成virtualDom ,这是react自己内部构建的一套对象体系,基于jsx中的属性描述构建成视图中真实DOM的相关描述,具体通过 React.createElement(type , props , children)
  • 将虚拟dom构建成真实dom
  • 补充: 第一次渲染是直接从虚拟dom----> 真实dom,之后的每次视图更新都是根据diff比对进行计算,生成两次的差异部分的PATH布丁包

在这里插入图片描述

在https://babeljs.io中看一下具体的编译后结果 在这里插入图片描述
将右侧编译后的代码在vs code中展示如下: 在这里插入图片描述
打印出来可以看到 在这里插入图片描述
在这里插入图片描述

virtualDOM = {
$$typeof : Symbol(react.element),
ref: null,
key : null ,
type: 标签名或「组件名」
props : {
// 元素的相关属性,className,x,y,title …
// children : 子节点信息「没有子节点则没有此属性,若只有一个子节点为对象,若有多个子节点则为数组,每个元素为子节点virtualDom对象」
} ,
}

以上是react内部的创建虚拟dom的过程,接下来是通过render方法将virtualDom创建成真实dom,然后浏览器渲染

react.render() ===> 构建真实dom

v16 和 v18 语法上有些差异
v16 : ReactDom.render(<> …</> , document.getElementById(‘root’))
v18 : const root = ReactDom.createRoot(document.getElementById(‘root’)) root.render(<>…</>)

模拟一下大概的render处理
在这里插入图片描述

先封装一个简单的对象遍历方法,方便对节点对象操作在这里插入图片描述

这是我所了解到的react处理渲染大致流程,如有遗漏,欢迎补充交流

相关推荐

  1. react 父子组件的渲染机制 | 优化手段

    2024-04-22 08:40:06       39 阅读
  2. <span style='color:red;'>react</span>-<span style='color:red;'>jsx</span>

    react-jsx

    2024-04-22 08:40:06      40 阅读
  3. React 元素渲染

    2024-04-22 08:40:06       64 阅读
  4. REACT 条件渲染

    2024-04-22 08:40:06       44 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-22 08:40:06       106 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-22 08:40:06       116 阅读
  3. 在Django里面运行非项目文件

    2024-04-22 08:40:06       95 阅读
  4. Python语言-面向对象

    2024-04-22 08:40:06       103 阅读

热门阅读

  1. 深入理解计算机网络:从基本原理到实践应用

    2024-04-22 08:40:06       40 阅读
  2. 每天学习一个Linux命令之join

    2024-04-22 08:40:06       41 阅读
  3. Python基本数据结构和常见算法

    2024-04-22 08:40:06       42 阅读
  4. vue学习

    2024-04-22 08:40:06       38 阅读
  5. 面向对象设计与分析(41)建造者模式builder

    2024-04-22 08:40:06       35 阅读
  6. MongoDB聚合运算符:$setEquals

    2024-04-22 08:40:06       38 阅读
  7. PhpStorm环境配置与应用

    2024-04-22 08:40:06       38 阅读
  8. Vue.js之MVVM设计模式

    2024-04-22 08:40:06       35 阅读