Mini-React

news/2024/9/9 14:05:50

jsx

jsx 是React中对于JavaScript的语法扩展,允许在JavaScript中去写类似于HTML的代码。使得开发者能够以一种更直观和声明式的方式去编写用户界面

vdom

vdom是React为了提高性能而去引入的一个虚拟的dom表示。
它是一个轻量级的 JavaScript 对象,用于描述真实 dom 树的结构。vdom 的核心思想是通过减少直接操作真实 dom 的次数来提高应用的渲染性能。

当react组件状态发生变化的时候,React会生成一个新的vdom树,与上一次的vdom树进行差异对比。并且找出实际发生变化的部分,并将这些变化去应用到真实的dom上,从而减少不必要的dom操作

我们写的jsx代码最终会被转换为JavaScript 对象,这些对象就是vdom的表示形式。有type,children,props等属性

createElement

React内部的一个方法。用于创建新的React元素,这个方法是jsx转换过程的一部分。当jsx代码被编译的时候,他会转换为React.createElement调用

const createTextNode = (text) => {
    return {
        type: TEXT_NODE,
        props: {
            nodeValue: text,
            children: []
        },
    }
}
const createElement = (type, props, ...children) => {
    return {
        type,
        props: {
            ...props,
            children: children.map(child => {
                return typeof child === 'string' || typeof child === 'number' ? createTextNode(child) : child
            })
        }
    }
}

Render

将React元素渲染到DOM节点上的过程。负责将vdom转换成真实的DOM节点,并append到指定的容器中(根节点root)
执行过程:

  • 通过type来创建不同的dom节点
  • 遍历props给dom节点设置对应的attribute
  • 遍历children去递归的创建dom节点,设置熟悉。重复上面两步
  • 然后把创建好的dom节点append到父节点中
  • 最后append到根节点中,也就是我们定义好的root节点。

但是整个过程是递归的,且递归不可中断,如果页面层级过多会导致 js占用线程时间过程,影响页面的渲染

React15架构的缺点

采用了递归去渲染更新页面。由于递归执行,所以更新一旦开始,中途就无法中断,当层级很深的时候,就会产生卡顿

如何解决的?

在 React16 中,将递归不可中断的更新改为了异步可中断更新

Fiber

fiber 节点表示一个最小的可执行工作单元。也就是一种新的数据结构,保存了 tag key type stateNode 等相关信息

React Fiber通过分片 slicing 和优先级调度 priority scheduling 来解决递归不可中断的问题

需要改为异步可中断的更新后,之前的 vdom 的数据结构就不太行了,这里就引出了 fiber 架构。采用链表的形式来表示当前的 dom 树

通过链表的 child sibling return 维护形成了一颗 fiber 树,这样我们就可以通过指针明确的知道当前执行到哪个 fiber 节点,当浏览器空闲的时候就去执行

…待完善function 组件,useState useEffect部分

感谢崔大的mini-react课程,下面是B站地址
https://space.bilibili.com/175301983/


http://lihuaxi.xjx100.cn/news/2142340.html

相关文章

软考高级架构师:系统性能设计-阿姆达尔定律概念和例题

一、AI 讲解 系统性能设计中的一个重要概念是阿姆达尔定律(Amdahl’s Law)。阿姆达尔定律是由吉恩阿姆达尔(Gene Amdahl)在1967年提出的,用于评估系统性能提升的理论上限,特别是在考虑并行计算时。该定律表…

MySQL两表联查之分组成绩第几问题

MySQL 数据库操作实践:两表联查之分组成绩第几问题 在本篇博客中,我将展示MySQL 从创建表、到插入数据,并进行一些复杂的查询操作。 1. 建立表格 首先,我们创建两个表:department(部门)和 em…

Vue3:重构Pinia的store,使用组合式写法实现

一、情景说明 之前的count.ts和loveTalk.ts都是选项式写法 这里,重构成Vue3官方建议的组合式写法(Composition) 二、案例 以loveTalk.ts为例 1、选项式(Options)写法 import {defineStore} from pinia import axios from axios import {nanoid} from nanoidexpo…

朗之万方程,机器学习与液体中的粒子运动

目录 一、说明二、朗之万方程的诞生2.1 牛顿力学2.2 流体中的随机运动 三、小质量物体布朗运动方程四、布朗运动的Python代码五、稳定性讨论5.1 波尔兹曼分布5.2 梯度下降算法 六、随机梯度下降(SGD)和小批量梯度下降七、机器学习与物理,作为…

【精品标准】最新数据安全评估标准合集

最新数据安全评估标准合集,以下是资料的目录,共12份。如需下载,请前往星球查阅和获取:https://t.zsxq.com/18JrHhWtQ 1、网络安全标准实践指南 2、数据安全风险评估方法 3、个人信息安全影响评估指南 4、数据出境安全评估指南 5、…

图神经网络实战(7)——图卷积网络(Graph Convolutional Network, GCN)详解与实现

图神经网络实战(7)——图卷积网络详解与实现 0. 前言1. 图卷积层2. 比较 GCN 和 GNN2.1 数据集分析2.2 实现 GCN 架构 小结系列链接 0. 前言 图卷积网络 (Graph Convolutional Network, GCN) 架构由 Kipf 和 Welling 于 2017 年提出,其理念是…

分发饼干(C++ 贪心)

目录 题目需求 贪心算法思想 什么是贪心 贪心算法的使用 贪心算法的优缺点 代码实现 后言 题目需求 假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。 对每个孩子 i,都有一个胃口值 g[i]&…

HTML - 你是如何理解link和@import的

难度级别:初级及以上 提问概率:55% link是我们非常熟悉的一个HTML标签,用于引入CSS文件,而import则存在于CSS文件内部,用于再次引入其他的CSS文件。所以很显然,执行顺序上…