慕课网-React18内核探秘:手写React高质量源码迈向高阶开发

3/17/2024

# 课程介绍:

从0到1手把手编写 React 高质量核心源码
提升复杂代码设计思维,助你成为编程高手
掌握源码本质是成为高手的必经之路,亲自编写一遍源码更是搞懂底层本质最有效的方式

# 课程目录:

  • # 第1章 课程简介

    导学介绍课程内容,及你所获得~

    • 1-1 导学 (07:34)
  • # 第2章 登高望远,手写源码前的思想准备

    建立全局观,为后续在源码中吸取精华做好思想准备,避免就源码而分析源码。

    • 2-1 思想准备01-本章介绍 (03:12)
    • 2-2 思想准备02-源码观 (06:31)
    • 2-3 思想准备03-React是什么 (20:46)
    • 2-4 思想准备04-React架构演进过程 (08:39)
    • 2-5 思想准备05-树立数据结构与算法的意识 (02:58)
    • 2-6 思想准备06-树立用原子视角看问题的意识 (02:19)
    • 2-7 思想准备07-理解React源码学习的基本方法 (07:28)
    • 2-8 思想准备08-小结 (01:19)
  • # 第3章 原始版-初始化渲染:实现最原始的渲染过程

    实现初次渲染的基础逻辑,初步体验源码的魅力。

    • 3-1 -本章介绍 (04:30)
    • 3-2 -环境搭建 (11:29)
    • 3-3 -虚拟DOM与真实DOM的实况对比 (15:09)
    • 3-4 -JSX的相关概念和原理 (10:53)
    • 3-5 -React和ReactDOM职责划分 (04:41)
    • 3-6 -createElement (22:14)
    • 3-7 -render函数 (21:18)
    • 3-8 -setPropsForDom (08:30)
    • 3-9 -初始化渲染调试 (15:07)
    • 3-10 -思考题 (06:31)
    • 3-11 -小结 (00:45)
  • # 第4章 原始版-引入函数组件与类组件提升渲染能力

    理解类组件与函数组件的本质,理解组件在React中的地位。

    • 4-1 本章介绍 (02:10)
    • 4-2 组件概念介绍 (09:31)
    • 4-3 实现函数组件的基础功能 (14:38)
    • 4-4 类组件的基本实现 (15:32)
    • 4-5 类组件的更新机制分析 (10:12)
    • 4-6 类组件setState函数的实现 (17:39)
    • 4-7 类组件setState函数的实现 (18:05)
    • 4-8 事件合成机制原理介绍 (07:58)
    • 4-9 实现事件合成机制 (25:00)
    • 4-10 实现事件合成机制 (21:02)
    • 4-11 ref原理分析 (15:08)
    • 4-12 原生标签和类组件ref的实现 (06:11)
    • 4-13 引入forwardRef的底层逻辑 (12:48)
    • 4-14 forwardRef的实现 (11:22)
    • 4-15 组件相关代码调试 (11:05)
    • 4-16 思考题与解答 (04:32)
    • 4-17 小结 (01:09)
  • # 第5章 原始版-对渲染过程进行优化-DOM DIFF

    DOM DIFF是React进行性能优化的一个重要举措,也是面试的常考点。

    • 5-1 -本章介绍 (03:19)
    • 5-2 原理分析 (20:25)
    • 5-3 原理分析 (13:04)
    • 5-4 源码实现-简单场景-1 (19:11)
    • 5-5 源码实现-简单场景-2 (16:13)
    • 5-6 源码实现-复杂场景-1 (21:48)
    • 5-7 源码实现-复杂场景-2 (15:04)
    • 5-8 源码实现-代码调试 (17:03)
    • 5-9 源码实现-代码调试 (11:33)
    • 5-10 -思考题和解答 (07:18)
    • 5-11 -小结 (01:32)
  • # 第6章 原始版-类组件的增强:生命周期

    为类组件添加生命周期的能力,增强类组件的功能。

    • 6-1 -本章介绍 (02:47)
    • 6-2 -生命周期的本质 (04:45)
    • 6-3 -生命周期图的观察 (07:06)
    • 6-4 -常用生命周期函数案例 (22:21)
    • 6-5 -常用生命周期函数代码实现 (11:31)
    • 6-6 -shouldComponentUpdate案例 (07:42)
    • 6-7 -shouldComponentUpdate源码实现 (07:57)
    • 6-8 -getDefirvedStateFromProps案例 (13:49)
    • 6-9 -getDefirvedStateFromProp源码实现 (05:15)
    • 6-10 -getSnapshotBeforeUpdate案例 (17:02)
    • 6-11 -getSnapshotBeforeUpdate源码实现 (15:07)
    • 6-12 -生命周期函数代码调试 (14:22)
    • 6-13 -思考题与解答 (03:13)
    • 6-14 -本章小结 (00:44)
  • # 第7章 原始版-进一步探索对渲染过程的性能优化

    性能优化的思想贯穿React源码学习的始终。

    • 7-1 -本章介绍 (01:32)
    • 7-2 -PureComponent案例 (08:42)
    • 7-3 -PureComponent源码实现 (11:08)
    • 7-4 -memo案例 (04:40)
    • 7-5 -1-memo源码实现 (19:07)
    • 7-6 -2-memo源码实现 (12:31)
    • 7-7 -代码调试 (13:49)
    • 7-8 -思考题 (10:58)
    • 7-9 -小结 (01:27)
  • # 第8章 原始版-引入日常开发的利器:Hooks

    Hooks在日常开发中已经取代了类组件,可以说是函数式编程的胜利。

    • 8-1 -本章介绍 (01:47)
    • 8-2 -Hooks概况 (05:36)
    • 8-3 -useSstate案例观察 (05:14)
    • 8-4 -useState源码实现 (20:04)
    • 8-5 -useReducer案例观察 (06:06)
    • 8-6 -useReducer源码实现 (04:56)
    • 8-7 -useEffect及useLayoutEffect源码实现 (08:46)
    • 8-8 -useEffect及useLayoutEffect源码实现 (25:24)
    • 8-9 -useRef案例和源码 (08:31)
    • 8-10 -useImperativeHandle案例和源码 (09:55)
    • 8-11 -useMemo及useCallback案例 (12:42)
    • 8-12 -useMemo及useCallback源码实现 (08:51)
    • 8-13 -代码调试 (10:54)
    • 8-14 -思考题及解答 (03:49)
    • 8-15 -小结 (02:18)
  • # 第9章 React18-React 性能革命:Fiber 架构的设计理念

    Fiber 架构,是 React 性能提升的里程碑,掌握其思想,为后续手写源码打下基础。

    • 9-1 -本章介绍 (01:18)
    • 9-2 -为什么需要Fiber架构 (18:33)
    • 9-3 -Fiber架构是什么 (05:25)
    • 9-4 -Fiber是什么 (08:57)
    • 9-5 -双缓冲策略 (07:44)
    • 9-6 -工作循环 (09:23)
    • 9-7 -并发模式 (04:06)
    • 9-8 -思考题及解答 (03:58)
    • 9-9 -本章小结 (01:58)
  • # 第10章 React18-初始化渲染

    Fiber架构下的初始化渲染与原始版的初始化渲染有什么不同?

    • 10-1 -本章介绍 (01:22)
    • 10-2 -环境准备 (11:10)
    • 10-3 -jsxDev代码实现 (18:45)
    • 10-4 createRoot-1 (17:15)
    • 10-5 createRoot-2 (21:28)
    • 10-6 -createRoot的类型表达实现及调试 (19:08)
    • 10-7 -render函数阶段划分 (03:05)
    • 10-8 updateContainer代码实现-1 (14:18)
    • 10-9 -2updateContainer代码实现 (07:21)
    • 10-10 -1-scheduleUpdateOnFiber (16:15)
    • 10-11 scheduleUpdateOnFiber-2 (15:56)
    • 10-12 beginWork1-1 (17:01)
    • 10-13 beginWork1-2 (15:33)
    • 10-14 beginWork2-1 (13:06)
    • 10-15 beginWork2-2 (13:31)
    • 10-16 -beginWork调试 (18:52)
    • 10-17 -completeWork1 (22:22)
    • 10-18 completeWork2-1 (24:32)
    • 10-19 completeWork2-2 (10:49)
    • 10-20 -completeWork3 (20:30)
    • 10-21 -completeWork调试 (24:57)
    • 10-22 commitWork代码实现-1 (24:48)
    • 10-23 commitWork代码实现-2 (22:20)
    • 10-24 -代码调试 (17:25)
    • 10-25 -函数组件 (14:47)
    • 10-26 -思考题 (04:24)
    • 10-27 -小结 (04:56)
  • # 第11章 React18-合成事件系统

    事件合成系统为什么存在?其理论基础是什么?

    • 11-1 -本章介绍 (02:13)
    • 11-2 -思路分析 (05:45)
    • 11-3 -事件名注册 (22:07)
    • 11-4 -注册监听事件 (22:55)
    • 11-5 事件派发主要逻辑-1 (21:04)
    • 11-6 事件派发主要逻辑-2 (23:34)
    • 11-7 -收集监听器函数 (14:58)
    • 11-8 -合成事件对象 (13:24)
    • 11-9 -事件函数回调 (10:10)
    • 11-10 -代码调试 (12:02)
    • 11-11 -思考题 (04:10)
    • 11-12 -小结 (03:00)
  • # 第12章 React18-组件更新

    Fiber架构下的更新流程,相较于原始版多了哪些环节。

    • 12-1 -本章介绍 (01:43)
    • 12-2 dom diff思路分析 1 (16:54)
    • 12-3 dom diff思路分析 2 (12:09)
    • 12-4 -单节点dom diff (21:41)
    • 12-5 多节点dom diff 1 (11:44)
    • 12-6 多节点dom diff 2 (14:55)
    • 12-7 -多节点dom diff 3 (19:29)
    • 12-8 多节点dom diff 4 (13:32)
    • 12-9 多节点dom diff 5 (15:43)
    • 12-10 -思考题和解答 (03:14)
    • 12-11 -小结 (02:18)
  • # 第13章 React18-Hooks

    Fiber架构下的Hooks,其代码组织结构有什么特征?

    • 13-1 -本章介绍 (02:10)
    • 13-2 useReducer挂载-1 (19:53)
    • 13-3 useReducer挂载-2 (14:23)
    • 13-4 -useReducer触发更新 (25:52)
    • 13-5 useReducer更新渲染1-1 (22:11)
    • 13-6 useReducer更新渲染1-2 (12:23)
    • 13-7 -useReducer更新渲染2-1 (13:53)
    • 13-8 -useReducer更新渲染2-2 (13:25)
    • 13-9 -useReducer更新渲染3 (16:42)
    • 13-10 -useReducer调试 (21:25)
    • 13-11 -useState (22:00)
    • 13-12 -useEffect挂载-1 (14:42)
    • 13-13 -useEffect挂载-2 (14:10)
    • 13-14 useEffect更新1-1 (14:00)
    • 13-15 useEffect更新1-2 (13:44)
    • 13-16 -useEffect更新2 (22:52)
    • 13-17 -useEffect调试 (07:30)
    • 13-18 -useLayoutEffect (18:29)
    • 13-19 -思考题及解答 (03:16)
    • 13-20 -小结 (01:55)
  • # 第14章 React18-Lane模型与优先级

    二进制在Lane模型中的妙用。

    • 14-1 -本章介绍 (03:41)
    • 14-2 -本章介绍 (03:41)
    • 14-3 -二进制的计算 (23:17)
    • 14-4 -最小堆算法原理 (14:02)
    • 14-5 -最小堆算法实现-1 (14:10)
    • 14-6 -最小堆算法实现-2 (15:07)
    • 14-7 -React18优先级体系 (10:10)
    • 14-8 -小结 (02:46)
  • # 第15章 React18-调度系统

    调度系统。

    • 15-1 -本章介绍 (05:34)
    • 15-2 -调度核心逻辑1 (19:16)
    • 15-3 调度核心逻辑2-1 (14:53)
    • 15-4 调度核心逻辑2-2 (12:26)
    • 15-5 -ReactFiberLane和ReactEventPriority-1 (15:49)
    • 15-6 -ReactFiberLane和ReactEventPriority-2 (17:21)
    • 15-7 Lane模型下的更新队列-1 (26:05)
    • 15-8 Lane模型下的更新队列-2 (21:39)
    • 15-9 Lane模型下的更新队列-3 (08:13)
    • 15-10 -加入优先级的初始化渲染 (21:19)
    • 15-11 -本章小结 (02:28)
  • # 第16章 React18-并发渲染

    最小堆算法的利用,与工作循环的良好配合。

    • 16-1 -本章介绍 (01:23)
    • 16-2 -同步渲染 (16:20)
    • 16-3 -并发渲染 (20:15)
    • 16-4 -思考题 (02:02)
    • 16-5 -小结 (04:13)

本课程已完结

# 下载地址:

慕课网-React18内核探秘:手写React高质量源码迈向高阶开发-小白自学网 (opens new window)