当前位置: 首页 > news >正文

React 元素的生命周期

文章目录

  • 前言
    • 🧱 一、React Element 是什么?
    • 🧠 二、React 元素生命周期总览图
    • 🚦 三、生命周期阶段详解(函数组件为例)
    • 🧩 四、可视化:函数组件挂载过程(简化流程图)
    • 🔁 五、更新过程(例如:点击按钮改变文本)
    • ❌ 六、卸载过程(如条件渲染中被隐藏的组件)
    • 🧪 补充:Fiber 中如何处理 Element?
    • ✅ 总结一句话


前言

可视化地讲解 React 元素(Virtual DOM)的生命周期,包括:

  1. React Element 是什么
  2. 从 JSX 到真实 DOM 的全过程
  3. 涉及的生命周期钩子
  4. 组件挂载 / 更新 / 卸载的流程图

🧱 一、React Element 是什么?

React Element 是 JSX 表达式转换后的结果,它只是一个用于描述 UI 的普通 JS 对象

// JSX
<h1 className="title">Hello</h1>// 被编译为:
React.createElement('h1', { className: 'title' }, 'Hello')// 返回:
{$$typeof: Symbol(react.element),type: 'h1',props: {className: 'title',children: 'Hello'}
}

它不是 HTML 也不是 DOM,而是虚拟 DOM,用于告诉 React:我要渲染什么内容。


🧠 二、React 元素生命周期总览图

[JSX] --> [React.createElement()] --> [Virtual DOM Tree]|[Reconciliation (Diff)]|[Fiber 架构调度 + commit 阶段]|[真实 DOM 创建/更新]↓[组件生命周期钩子触发]

🚦 三、生命周期阶段详解(函数组件为例)

阶段发生什么涉及内容
① 创建阶段JSX 被转为 React Element 对象React.createElement
② 构建虚拟 DOM所有 Element 被组成树结构Fiber Tree
③ 调和阶段与上次的 Fiber 比对差异reconciliation
④ 提交阶段更新真实 DOM + 触发生命周期钩子useEffect、DOM API
⑤ 更新阶段状态变化 → 触发新 Element → 重走 Diff 流程useEffect, useMemo
⑥ 卸载阶段DOM 被移除 → 清理副作用useEffect cleanup

🧩 四、可视化:函数组件挂载过程(简化流程图)

            App()↓JSX: <h1>Hello</h1> 返回↓React.createElement → React Element↓Fiber 构建(VNode 树)↓Diff:新 vs 旧(首次无旧 → 全部挂载)↓Commit:创建 DOM(document.createElement)↓插入页面(appendChild)↓useEffect(() => { ... }, []) 触发

🔁 五、更新过程(例如:点击按钮改变文本)

setState() 触发↓
新 JSX 生成新 Element↓
新 Fiber Tree 与旧 Fiber Tree Diff↓
找出差异(如文本变化)↓
只更新需要变更的 DOM(如 innerText)↓
commit 阶段完成↓
useEffect() 执行更新后的副作用

❌ 六、卸载过程(如条件渲染中被隐藏的组件)

Component 被从 JSX 移除↓
React Diff 检测到组件已不存在↓
Fiber 标记为 `deletion`↓
DOM 元素从页面中删除↓
useEffect cleanup 执行

🧪 补充:Fiber 中如何处理 Element?

  • 每个 React Element 会被包装为 Fiber 节点(FiberNode)
  • Fiber Tree 是一棵链式结构树(child → sibling → return)
  • rendercommit 两阶段分别处理计算 & DOM 更新

✅ 总结一句话

React Element 是 UI 的描述符,它的生命周期跨越了虚拟 DOM 构建、Fiber 调度、DOM 渲染与副作用清理,每一次 setState 其实都在触发一次“React Element → DOM” 的完整生命周期流。


相关文章:

  • 串扰的烦恼(Xtalk)
  • scons: *** [***\SConscript] ValueError : unsupported pickle protocol: 4
  • 基础数论一一同余定理
  • Asp.Net Core SignalR导入数据
  • VAS1085Q奇力科技LED驱动芯片车规级线性芯片
  • 8.3.1_冒泡排序
  • AI的发展过程:深度学习中的自然语言处理(NLP);大语言模型(LLM)详解;Transformer 模型结构详解;大模型三要素:T-P-G 原则
  • 《HarmonyOSNext弹窗:ComponentContent动态玩转企业级弹窗》
  • 告别excel:AI 驱动的数据分析指南
  • CentOS7自带的yum依然无法联网到官方源
  • 【C/C++】怎样设计一个合理的函数
  • 相机--单目相机
  • 7. 整数反转
  • Linux 内核 Slab 分配器核心组件详解
  • 基于51单片机和8X8点阵屏、独立按键的跳跃躲闪类小游戏
  • 如何在同一台电脑上安装并运行多个版本的 IntelliJ IDEA
  • xilinx的GT配置说明(一)
  • 【考研数学:高数6】一元函数微分学的应用(二)——中值定理、微分等式和微分不等式
  • AT2659低噪声放大器芯片
  • [KCTF]rev_babyrev
  • 做网站公司汉狮团队/百度seo关键词优化电话
  • wordpress4.8换成中文/黄山网站seo
  • 外贸海外网站推广/优化人员配置
  • 商丘行业网站建设开发公司/网络渠道有哪些
  • seo1网站查询/网络营销概述
  • 中山做百度网站的公司/1688黄页大全进口