React中父子组件生命周期的执行顺序

在 React 中,父子组件的生命周期执行顺序遵循一个清晰的规律:父组件先准备,子组件再挂载;子组件先卸载,父组件再清理

核心原则 :渲染阶段由父到子(render 递归),提交阶段(DOM 更新)再由子到父(componentDidMount/Update 递归)。


一、初始挂载阶段(Mounting)

顺序:父组件 getDerivedStateFromProps / render → 子组件生命周期 → 父组件 componentDidMount

详细步骤(以类组件为例):

  1. 父组件constructor
  2. 父组件getDerivedStateFromProps
  3. 父组件render
    → 此时解析出子组件实例,开始子组件的生命周期
  4. 子组件constructor
  5. 子组件getDerivedStateFromProps
  6. 子组件render
  7. 子组件componentDidMount
  8. 父组件componentDidMount

注意:componentDidMount 是子组件先执行,父组件后执行。


二、更新阶段(Updating)

触发条件:propsstate 改变。

2.1 由父组件 state 变化引起的更新

  1. 父组件getDerivedStateFromProps
  2. 父组件shouldComponentUpdate
  3. 父组件render
    → 重新生成子组件,触发子组件更新
  4. 子组件getDerivedStateFromProps
  5. 子组件shouldComponentUpdate
  6. 子组件render
  7. 子组件getSnapshotBeforeUpdate
  8. 子组件componentDidUpdate
  9. 父组件getSnapshotBeforeUpdate
  10. 父组件componentDidUpdate

2.2 由子组件自身 state 变化引起的更新

只会触发子组件自身的更新生命周期,父组件不受影响(除非子组件通过回调修改父组件 state)。


三、卸载阶段(Unmounting)

顺序:父组件先标记卸载 → 子组件 componentWillUnmount → 父组件 componentWillUnmount

  1. 父组件:决定卸载子组件(例如条件渲染移除子组件)
  2. 子组件componentWillUnmount
  3. 父组件componentWillUnmount

子组件先执行清理工作,父组件最后清理。


四、函数组件中的近似顺序(useEffect)

函数组件没有直接等价的生命周期,但 useEffect 的执行顺序模拟了部分行为:

阶段 类组件顺序 函数组件近似顺序
挂载 父 render → 子 render → 子 didMount → 父 didMount 父 render → 子 render → 子 useLayoutEffect → 父 useLayoutEffect → 子 useEffect → 父 useEffect
更新 父 render → 子 render → 子 didUpdate → 父 didUpdate 类似,但 cleanup 在上一次 effect 之前执行
卸载 子 willUnmount → 父 willUnmount 子 useEffect cleanup → 父 useEffect cleanup

注意:useEffect 是在浏览器完成布局与绘制之后 异步执行,所以 useEffect 中父子顺序仍然是子先于父(因为组件树是深度优先渲染的)。


五、关键总结

  • 挂载 :父 render 先完成,但父 componentDidMount 要等所有子组件挂载完才执行。
  • 更新 :父 render 先执行,然后子组件更新,最后父 componentDidUpdate
  • 卸载 :子组件先执行 componentWillUnmount,父组件最后执行。
  • 函数组件useEffect 的顺序是子先于父,但执行时间点在布局/绘制之后。

这个顺序保证了:

  • 子组件在父组件访问它们之前已经准备好(或已清理)
  • DOM 测量/滚动位置等操作可以在合适的时机进行
相关推荐
绝世唐门三哥1 小时前
ES6 --- import/export 全解析
开发语言·前端·javascript
小杍随笔1 小时前
【iNovel 前端架构深度解析:基于 Vue 3 + TypeScript + Tauri 的跨端小说写作工具】
前端·架构·typescript
yqcoder1 小时前
JavaScript 异步基石:Promise 完全指南
开发语言·前端·javascript
深度先生1 小时前
Windows 踩坑实录:better-sqlite3 安装、编译、打包报错彻底解决
前端
胡志辉1 小时前
Nginx CVE‑2026‑42945:隐藏18年高危漏洞被曝光(附解决方案)
前端·后端·nginx
Csvn1 小时前
Vue 性能优化实战指南
前端·vue.js
UXbot2 小时前
AI原型设计工具如何从PRD自动生成交互原型
前端·低代码·ui·交互·ai编程·原型模式
Csvn2 小时前
Vue 最佳实践
前端·vue.js
产品经理爱开发2 小时前
老师用AI开发的HTML教具如何在线托管访问
前端·html·ai编程·持续部署·源代码管理