【React18源码解析】(零)写在最开始

作为一个前端程序猿,React 是我工作中的重要工具。搞清楚它的源码实现,才能在使用它时知其然,知其所以然 。所以,我花了一些时间阅读它的源码,本系列 React18 源码解析,算是对自己学习过程的一个记录和分享吧。

版本迭代

我们知道,React 从 2013 年发布以来,经历了多个关键版本的更新,整体架构也发生了较大的变化。

React 0.x - 15.x

早期阶段,引入 JSX 写法,虚拟 DOM,基本的 class 组件。

React 16

首次引入 Fiber 架构,为后续并发渲染打下基础。

React 16.8

hooks 正式发布,函数式组件具备状态、副作用等功能,鼓励使用函数式组件代替 class 组件。

React 18

  • 并发渲染(Concurrent Rendering)正式上线。
  • startTransition 标记低优先级更新。
  • 自动批处理等。

React 19

  • useFormStatus / useFormState 管理表单提交、错误、状态。
  • useOptimistic 支持乐观更新(先展示、后提交)。
  • 准备迎接 React Compiler(自动性能优化)。

这些更新中,React18 是一个具有重大意义的版本。既 React16 引入 Fiber 后,又一次大的架构升级,它改变渲染模型,开启了并发渲染的时代。所以,本系列中,我们将针对 React 18 的源码进行深入解析。

获取源码

首先,从 github 找到 React 的源码git clone 到本地。

然后查看 18.x 系列的 tag,并 git checkout 到相应版本。

perl 复制代码
git tag | grep v18

git checkout v18.0.0

目录结构

React 源码使用 monorepo 的形式管理。

根目录

根目录结构大致如下:

go 复制代码
nestjs/
├── packages/
├── scripts/
├── fixtures/
├── ...
└── package.json

其中每个子目录的分工为:

  • packages:核心源码模块。
  • scripts:各种脚本,构建发布、性能基准测试等。
  • fixtures:用于测试的示例项目(如 dom、concurrent 模式等)。

packages 目录

下面来看下包含核心源码的 packages 目录:

java 复制代码
packages/
├── react/
├── react-dom/
├── react-reconciler/
├── scheduler/
├── shared/
├── react-server/
├── react-native-renderer/
├── react-devtools/
└── ...

react

React 对外暴露的顶层 API。比如 React.createElement 、hooks API (useStateuseEffect) 等。

react-dom

处理 DOM 渲染逻辑,与浏览器 DOM 操作直接相关的 API。比如 ReactDOM.renderReactDOM.creteRootReactDOM.createPortal 等。

react-reconciler

核心调和器,包含 Fiber 树构建、调和(diff)逻辑、更新等。

scheduler

调度器,用于控制任务优先级、任务延迟、中断恢复等,实现并发渲染。

shared

多个包之间共享的通用工具函数和常量。

react-server

用于服务端组件(React Server Components)。

react-native-renderer

React Native 渲染器。

react-devtools

React 开发者工具。

总结

本章介绍了 React 版本的迭代过程以及源码的目录结构。源码按照功能模块,通过 monorepo 的形式组织,其中比较核心的是 react、react-dom、react-reconciler、scheduler 这几个包,后续我们会围绕它们的实现深入解析。

相关推荐
孟陬11 小时前
HTML 处理以及性能对比 - Bun 单元测试系列
react.js·单元测试·bun
小高00711 小时前
React useMemo 深度指南:原理、误区、实战与 2025 最佳实践
前端·javascript·react.js
一颗奇趣蛋12 小时前
React.memo & useMemo:为什么 React 里「看起来没变的组件」还是渲染了
前端·react.js
龙井>_<13 小时前
vue项目封装axios请求,支持判断当前环境及判断token是否过期等等(详细教程,可复制粘贴代码)
前端·javascript·vue.js·前端框架
Ice_Sugar_713 小时前
React 腾讯面试手写题
javascript·react.js·ecmascript
卸任14 小时前
Electron自制翻译工具:自动更新
前端·react.js·electron
小喷友16 小时前
Next.js 中的 Edge Middleware 实战
前端·react.js·next.js
前端美少女战士19 小时前
post方法下载文件,需做哪些特殊处理
javascript·react.js
Jimmy21 小时前
React 性能优化:从慢到闪电般快
前端·javascript·react.js
江城开朗的豌豆21 小时前
React Hooks 真香定律:告别Class组件,我为什么回不去了?
前端·javascript·react.js