ReactJS 中的 JSX工作原理

news2025/6/2 19:15:47

文章目录

  • 前言
    • ✅ 1. JSX 是什么?
    • 🔧 2. 编译后的样子(核心机制)
    • 🧱 3. `React.createElement` 做了什么?
    • 🧠 4. JSX 与组件的关系
    • 🔄 5. JSX 到真实 DOM 的过程
    • 📘 6. JSX 与 Fragment、条件渲染等底层行为
    • ⚠️ 7. 注意事项
    • ✅ 总结
  • JSX 编译后如何通过 Fiber 架构驱动渲染更新
    • ✅ 一、React 渲染整体流程概览(React 18+)
    • 🧠 二、什么是 Fiber 架构?
      • 📦 一个 Fiber 节点结构简化如下:
    • 🔄 三、Reconciliation(协调 / diff)机制
      • Diff 规则核心简化:
    • ⚙️ 四、Commit 阶段(更新真实 DOM)
    • ⏱️ 五、Concurrent Mode(React 18)
      • 🌟 调度示意(非阻塞渲染):
    • 📌 六、双缓冲机制(双 Fiber Tree)
    • 🎯 七、性能优化的启示
    • ✅ 总结:JSX 到 DOM 的底层机制主线
  • ⏱️ React Fiber 调度与中断机制:时间切片、优先级调度、任务恢复
    • ✅ 1. 为什么需要中断渲染?
      • 问题:
    • ✅ 2. Fiber 如何解决这个问题?
      • 🎯 利用:
    • 📦 3. 任务调度:Scheduler 的优先级系统
    • ⏳ 4. 时间切片机制(Time Slicing)
    • 🔁 5. 中断与恢复机制
    • ⚙️ 6. Concurrent 模式的核心优势
    • 🧠 7. 示例:startTransition 与中断渲染
    • ✅ 8. 总结:Fiber 调度机制的精髓
    • 📘 延伸(可选深入)


前言

ReactJS 中的 JSX(JavaScript XML)看起来像 HTML,但它其实只是语法糖,在底层是被编译成 React.createElement(...) 调用的 JavaScript 代码。理解其底层机制对优化性能、调试问题、使用 Hooks 等非常重要。


✅ 1. JSX 是什么?

JSX 是 JavaScript 的语法扩展,允许你这样写 UI:

const element = <h1>Hello, world!</h1>;

它看起来像 HTML,但不是。它不会被浏览器直接执行,而是会在构建阶段被转译为 JavaScript。


🔧 2. 编译后的样子(核心机制)

这段代码:

const element = <h1 className="title">Hello</h1>;

会被 Babel 编译为:

const element = React.createElement(
  'h1',
  { className: 'title' },
  'Hello'
);

等价于:

{
  type: 'h1',
  props: {
    className: 'title',
    children: 'Hello'
  }
}

最终,React 用这些对象来构建虚拟 DOM(Virtual DOM)。


🧱 3. React.createElement 做了什么?

它会返回一个React 元素对象

{
  $$typeof: Symbol(react.element),
  type: 'h1',
  key: null,
  ref: null,
  props: {
    className: 'title',
    children: 'Hello'
  },
  _owner: null
}

这是一个纯 JS 对象,描述了 UI 的结构。不是 DOM 节点,还没有真正渲染。


🧠 4. JSX 与组件的关系

JSX 中也可以使用组件:

<MyButton text="Click me" />

被编译为:

React.createElement(MyButton, { text: "Click me" });

最终调用你自己写的 MyButton(props) 函数,返回另一个 createElement(...)


🔄 5. JSX 到真实 DOM 的过程

  1. JSX 被编译为 React.createElement(...)
  2. React 构建虚拟 DOM 树
  3. React 将虚拟 DOM diff(比对)旧的 DOM 树
  4. React 使用 DOM API 更新真实 DOM(插入、删除、替换节点)

📘 6. JSX 与 Fragment、条件渲染等底层行为

  • <></>React.createElement(React.Fragment, null, ...)
  • 条件渲染:{condition && <div>Yes</div>} → 三元或逻辑判断
  • 循环渲染:{list.map(item => <li>{item}</li>)} → 多次 createElement 调用

⚠️ 7. 注意事项

特性底层意义
JSX 只能有一个根节点因为 React.createElement 只能返回一个元素
不支持 if 语句直接写在 JSXJSX 是表达式,需要用三元或外部逻辑
自闭和标签 <MyComp />转译为 React.createElement(MyComp)
不能直接渲染对象[object Object] 错误是因为 createElement 接收了非法 children

✅ 总结

概念作用
JSXReact 的语法糖,用来描述 UI 结构
Babel把 JSX 编译为 React.createElement()
React.createElement创建虚拟 DOM 描述对象
虚拟 DOM一个 JS 对象树,最终映射为真实 DOM
渲染机制Diff + 更新 DOM 节点(最小化操作)

JSX 编译后如何通过 Fiber 架构驱动渲染更新

这一主线,系统讲解 React 的底层工作机制,包括:


✅ 一、React 渲染整体流程概览(React 18+)

graph TD
A[JSX] --> B[createElement]
B --> C[构建虚拟 DOM]
C --> D[Fiber 架构构建 Fiber Tree]
D --> E[Reconciliation(diff)]
E --> F[Commit 阶段:更新真实 DOM]

🧠 二、什么是 Fiber 架构?

Fiber 是 React 从 v16 开始的核心架构,其主要目标是:

  • 支持任务中断(可暂停)
  • 支持异步渲染(并发模式)
  • 增强调度控制
  • 支持优先级(Urgent、Normal、Idle)

Fiber = 一种“工作单元”结构,用链表组织虚拟 DOM,便于逐个处理、可打断、可恢复


📦 一个 Fiber 节点结构简化如下:

interface Fiber {
  type: string | FunctionComponent
  stateNode: HTMLElement | null
  child: Fiber | null
  sibling: Fiber | null
  return: Fiber | null
  alternate: Fiber | null // 双缓存机制
  effectTag: 'UPDATE' | 'PLACEMENT' | 'DELETION'
}

🔄 三、Reconciliation(协调 / diff)机制

目的:比较新旧 virtual DOM,找到最小变更,生成 effectList 用于更新真实 DOM。

Diff 规则核心简化:

  • 同层比较:只比较同级节点
  • Key 区分同类型组件:用于 map 渲染性能优化
  • 类型不同 → 全替换
  • 类型相同 → 尝试复用

⚙️ 四、Commit 阶段(更新真实 DOM)

当 Fiber 树构建完毕后,进入 commit 阶段:

// commitWork
switch (fiber.effectTag) {
  case 'PLACEMENT': // 插入
    parent.appendChild(fiber.stateNode);
    break;
  case 'UPDATE': // 属性或内容变更
    updateDOM(fiber.stateNode, oldProps, newProps);
    break;
  case 'DELETION':
    parent.removeChild(fiber.stateNode);
    break;
}

⏱️ 五、Concurrent Mode(React 18)

React 18 引入并发渲染模式,依赖 Fiber 实现:

特性描述
startTransition标记可中断更新(非紧急)
自动批处理setState 自动分组,不再需要 unstable_batchedUpdates
useDeferredValue延迟非关键状态同步更新
useTransition标记 UI “pending” 状态,支持 loading skeleton 等过渡体验
ReactDOM.createRoot默认进入 Concurrent 模式

🌟 调度示意(非阻塞渲染):

startTransition(() => {
  setValue(input);
})

React 会调度优先级高的操作(如输入)先渲染,低优先的任务稍后处理。


📌 六、双缓冲机制(双 Fiber Tree)

React 使用 currentworkInProgress 两棵 Fiber Tree,交替使用:

current正在显示的 UI
workInProgress当前计算的新状态

当 Reconciliation 完成,React 会“交换”两棵树,实现 快照切换


🎯 七、性能优化的启示

场景原因优化策略
大量列表重复渲染Key 设计不当导致全部 diff用稳定 Key
卡顿严重所有状态更新同步使用 startTransition, useDeferredValue
多组件嵌套,重渲染过多props 未 memo使用 React.memouseMemo, useCallback
复杂条件渲染JSX 重计算多使用懒加载 React.lazy, Suspense

✅ 总结:JSX 到 DOM 的底层机制主线

阶段关键内容
编译JSX → createElement → 虚拟 DOM
构建Fiber 树结构,链表连接
diffReconciliation 识别变化
更新commit 阶段执行 effect list 操作真实 DOM
并发Fiber 允许中断、恢复、优先级调度
优化利用 Hook + memo + key + transition

⏱️ React Fiber 调度与中断机制:时间切片、优先级调度、任务恢复

React Fiber 架构最大的突破之一就是它将渲染任务拆分为“工作单元”(Fiber 节点),并使用浏览器的空闲时间或非阻塞方式来执行这些任务。


✅ 1. 为什么需要中断渲染?

问题:

React 早期(v15 及以前)渲染是同步的:

ReactDOM.render(<App />, root);

如果组件树很大,JS 线程会被“卡死”,导致:

  • 输入卡顿
  • 动画掉帧
  • 无法响应用户操作

✅ 2. Fiber 如何解决这个问题?

🧠 核心思想:把渲染拆成很多小任务,用浏览器空闲时间分批执行,并可中途暂停与恢复。

🎯 利用:

requestIdleCallback(callback)

或(React 18 起)用:

scheduler.unstable_scheduleCallback(priority, callback)

📦 3. 任务调度:Scheduler 的优先级系统

React 使用内部调度器(scheduler)给任务分配优先级:

调度级别描述示例
Immediate (最高)立刻执行setState 同步
UserBlocking用户操作相关输入、点击
Normal默认更新内容变化
Low非关键动画、日志
Idle不重要预加载

⏳ 4. 时间切片机制(Time Slicing)

Fiber 会把任务拆成一个个 unit of work,然后循环调度:

while (nextUnitOfWork && shouldYield() === false) {
  nextUnitOfWork = performUnitOfWork(nextUnitOfWork);
}

shouldYield() 检查是否要让位给浏览器,防止掉帧。

function shouldYield() {
  return performance.now() >= deadline;
}

🔁 5. 中断与恢复机制

如果 shouldYield()true,Fiber 会 中断当前工作,然后把当前状态保存在 workInProgress 上,下次从这个点继续:

// workInProgress 保存当前 fiber 的指针链表状态

浏览器空闲后,React 会再次调度:

requestIdleCallback(workLoop)

⚙️ 6. Concurrent 模式的核心优势

能力说明
✋ 中断渲染过程可被暂停
🔁 恢复下一帧继续渲染剩余部分
⚖️ 优先级用户输入优先渲染,非关键可延后
🎨 更流畅输入不卡顿,动画更自然
🧠 更智能可实现并行 diff、预渲染、Suspense fallback 等功能

🧠 7. 示例:startTransition 与中断渲染

import { startTransition } from 'react'

function handleInput(e) {
  const value = e.target.value

  // 非紧急更新,允许中断
  startTransition(() => {
    setFilteredList(filterBigList(value))
  })
}

用户打字不会因为 setFilteredList() 而卡顿,因为这是一个“可中断更新”。


✅ 8. 总结:Fiber 调度机制的精髓

内容
拆分Fiber 把渲染任务拆成小单元
调度使用 scheduler 或 requestIdleCallback 进行执行调度
中断shouldYield() 决定是否让步给浏览器主线程
恢复保存中间状态于 Fiber,支持恢复渲染
优先级按任务重要程度进行排序调度,保障交互流畅性

📘 延伸(可选深入)

如果你还想进一步了解:

  1. Lane Model(React 18 调度核心)
  2. React Scheduler 实现(源码级)
  3. Suspense + Fiber 如何协同暂停渲染树
  4. Concurrent Features:如 React.lazy, Streaming SSR

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2394185.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《STL--stack 和 queue 的使用及其底层实现》

引言&#xff1a; 上次我们学习了容器list的使用及其底层实现&#xff0c;相对来说是比较复杂的&#xff0c;今天我们要学习的适配器stack和queue与list相比就简单很多了&#xff0c;下面我们就开始今天的学习&#xff1a; 一&#xff1a;stack&#xff08;后进先出&#xff…

基于springboot的医护人员排班系统设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…

CRISPR-Cas系统的小型化研究进展-文献精读137

Progress in the miniaturization of CRISPR-Cas systems CRISPR-Cas系统的小型化研究进展 摘要 CRISPR-Cas基因编辑技术由于其简便性和高效性&#xff0c;已被广泛应用于生物学、医学、农学等领域的基础与应用研究。目前广泛使用的Cas核酸酶均具有较大的分子量&#xff08;通…

利用python工具you-get下载网页的视频文件

有时候我们可能在一个网站看到一个视频&#xff08;比如B站&#xff09;&#xff0c;想下载&#xff0c;但是页面没有下载视频的按钮。这时候&#xff0c;我们可以借助python工具you-get来实现下载功能。下面简要说下步骤 &#xff08;一&#xff09;因为使用的是python工具&a…

【stm32开发板】单片机最小系统原理图设计

一、批量添加网络标签 可以选择浮动工具中的N&#xff0c;单独为引脚添加网络标签。 当芯片引脚非常多的时候&#xff0c;选中芯片&#xff0c;右键选择扇出网络标签/非连接标识 按住ctrl键即可选中多个引脚 点击将引脚名称填入网络名 就完成了引脚标签的批量添加 二、电源引…

实验设计与分析(第6版,Montgomery)第5章析因设计引导5.7节思考题5.2 R语言解题

本文是实验设计与分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅珏生译) 第5章析因设计引导5.7节思考题5.2 R语言解题。主要涉及方差分析&#xff0c;正态假设检验&#xff0c;残差分析&#xff0c;交互作用。 dataframe<-data.frame( Surfacec(74,64,60,92…

2025山东CCPC题解

文章目录 L - StellaD - Distributed SystemI - Square PuzzleE - Greatest Common DivisorG - Assembly Line L - Stella 题目来源&#xff1a;L - Stella 解题思路 签到题&#xff0c;因为给出的字母不是按顺序&#xff0c;可以存起来赋其值&#xff0c;然后在比较。 代码…

CentOS Stream 9 中部署 MySQL 8.0 MGR(MySQL Group Replication)一主两从高可用集群

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《MySQL技术精粹》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、前言 1、MySQL 8.0 中的高可用方案 2、适用场景 二、环境准备 1、系统环境说明…

pycharm 新UI 固定菜单栏 pycharm2025 中文版

pycharm 新UI 文件 -> 设置 -> 外观与行为 -> 外观 -> UI选项 -> 主菜单:显示在主工具栏上方. 即可固定

我的世界Java版1.21.4的Fabric模组开发教程(十一)创建方块

这是适用于Minecraft Java版1.21.4的Fabric模组开发系列教程专栏第十一章——创建方块。想要阅读其他内容&#xff0c;请查看或订阅上面的专栏。 方块(Block) 是构成Minecraft世界的主要组成部分&#xff0c;是组成游戏地图的最基本单元&#xff0c;也是模组开发的核心元素之一…

VR/AR 视网膜级显示破局:10000PPI 如何终结颗粒感时代?

一、传统液晶 “纱窗效应”&#xff1a;VR 沉浸体验的最大绊脚石 当用户首次戴上 VR 头显时&#xff0c;眼前密密麻麻的像素网格往往打破沉浸感 —— 这正是传统液晶显示在近眼场景下的致命缺陷。受限于 500-600PPI 的像素密度&#xff0c;即使达到 4K 分辨率&#xff0c;等效到…

系统思考:化繁为简的艺术

系统思考&#xff0c;其实是一门化繁为简的艺术。当我们能够把复杂的问题拆解成清晰的核心以及更加简单&#xff0c;从而提升团队的思考品质和行动品质&#xff0c;发挥最大的合力。 每个公司都想在某方面成为最优秀的&#xff0c;但是实际上具有穿透性的洞察力和摆脱虚荣心的清…

Angularjs-Hello

1 关于Angularjs 最近因为项目需要又要做这个&#xff0c;所以简单复习下。其实这个大概7&#xff0c;8年前就用过&#xff0c;当时做了几个简单页面觉得太简单就还是回去做嵌入式了。按照互联网技术的进化速度&#xff0c;本来以为早死在 沙滩上了&#xff0c;没想到现在还在坚…

Linux 1.0.4

父子shell linux研究的就是shell 打开两个窗口就是两个shell 终端的软件有很多 bash也是一个软件 我们在terminal里面再打开一个bash&#xff0c;然后再次使用ps命令发现多出来一个bash&#xff0c;之后点击exit只是显示了一个exit&#xff0c;这个只是退出了在terminal中打开…

Qt -下载Qt6与OpenCV

博客主页&#xff1a;【夜泉_ly】 本文专栏&#xff1a;【暂无】 欢迎点赞&#x1f44d;收藏⭐关注❤️ 前言 呃啊&#xff0c;本来就想在 Qt 里简单几个 OpenVC 的函数&#xff0c;没想到一搞就是一天。 我之前的开发环境是 Qt 5.14.2&#xff0c;使用 MinGW 7.3.0 64-bit 编…

机器学习无监督学习sklearn实战一:K-Means 算法聚类对葡萄酒数据集进行聚类分析和可视化( 主成分分析PCA特征降维)

本项目代码在个人github链接&#xff1a;https://github.com/KLWU07/Machine-learning-Project-practice/tree/main/1-Wine%20cluster%20analysis 如果对于聚类算法理论不理解可参考这篇之前文章机器学习中无监督学习方法的聚类&#xff1a;划分式聚类、层次聚类、密度聚类&…

可灵2.1 vs Veo 3:AI视频生成谁更胜一筹?

在Google发布Veo 3几天后,可灵显然感受到了压力,发布了即将推出的视频模型系列可灵 2.1的早期体验版。 据我了解,有三种不同的模式: 可灵 2.1 标准模式: 720p分辨率 仅支持图像转视频(生成更快,一致性更好) 5秒视频仍需20积分 可灵 2.1 专业模式: 1080p分辨率 仅在图…

LLM优化技术——Paged Attention

在Transformer decoding的过程中&#xff0c;需要存储过去tokens的所有Keys和Values&#xff0c;以完成self attention的计算&#xff0c;称之为KV cache。 &#xff08;1&#xff09;KV cache的大小 可以计算存储KV cache所需的内存大小&#xff1a; batch * layers * kv-he…

推荐几个不错的AI入门学习视频

引言&#xff1a;昨天推荐了几本AI入门书&#xff08;AI入门书&#xff09;&#xff0c;反响还不错。今天&#xff0c;我再推荐几个不错的AI学习视频&#xff0c;希望对大家有帮助。 网上关于AI的学习视频特别多。有收费的&#xff0c;也有免费的。我今天只推荐免费的。 我们按…

采用Bright Data+n8n+AI打造自动化新闻助手:每天5分钟实现内容日更

一、引言 在信息爆炸的时代&#xff0c;作为科技领域的内容创作者&#xff0c;我每天都要花费2-3小时手动收集行业新闻、撰写摘要并发布到各个社群。直到我发现Bright Datan8nAI这套"黄金组合"&#xff0c;才真正实现了从"人工搬运"到"智能自动化&qu…