【React】生命周期

React 16之前的生命周期分为三个阶段:挂载阶段(Mounting)、更新阶段(Updating)、卸载阶段(Unmounting)。而React 16及以后版本,引入了新的生命周期方法,同时也引入了钩子函数(Hooks),让函数式组件也能具有类组件的生命周期特性,因此react 的生命周期逐渐淡化。

1. 挂载阶段(Mounting)

在组件实例第一次被创建并插入到DOM中时触发。

  • constructor(): 组件的构造函数,在组件被创建时调用。通常用于初始化state和绑定事件处理函数。在构造函数中,需要通过super(props)调用父类的构造函数。

  • static getDerivedStateFromProps(props, state): 这是一个静态方法,用于在props发生变化时更新state。它接收props和state作为参数,并返回一个对象来更新state,或者返回null不更新state。该方法在组件实例化时和每次接收新的props时都会被调用,不管是初次挂载还是后续更新。

  • render(): 这是生命周期中唯一必须要实现的方法。它负责返回要渲染的React元素。render方法应该是一个纯函数,不应该有副作用,也不应该改变组件的状态。

  • componentDidMount(): 在组件被挂载到DOM后立即调用。常用于执行一些需要DOM节点的操作,比如网络请求、订阅事件等。

2. 更新阶段(Updating)

当组件的props或state发生变化时触发。

  • static getDerivedStateFromProps(props, state): 见上述说明。

  • shouldComponentUpdate(nextProps, nextState): 在组件接收到新的props或state时调用,用于决定是否重新渲染组件。默认返回true,表示应该重新渲染。可以在此方法中进行性能优化,比如对props或state的变化进行判断,如果不需要重新渲染则返回false。

  • **render():**见上述说明。

  • getSnapshotBeforeUpdate(prevProps, prevState): 在render方法之后、组件更新到DOM之前调用。它可以读取之前DOM的状态,并返回一个值作为参数传递给componentDidUpdate方法。

  • componentDidUpdate(prevProps, prevState, snapshot): 组件更新后调用。可以在此方法中进行DOM操作,或者对更新前后的props和state进行比较操作。

3. 卸载阶段(Unmounting)

当组件从DOM中移除时触发。

  • componentWillUnmount(): 在组件即将被卸载和销毁时调用。常用于执行一些清理操作,比如取消订阅、清除定时器等。

React 16之后的生命周期

除了上述生命周期方法外,React 16及以后版本引入了一些新的生命周期方法:

  • static getDerivedStateFromError(error): 当子组件发生错误时调用,用于捕获错误并更新state以渲染备用UI。

  • componentDidCatch(error, info): 在组件的子组件发生错误后调用,用于捕获错误信息,并记录错误。可以在此方法中执行错误处理逻辑,比如发送错误报告等。

钩子函数(Hooks)

React 16.8及以后版本引入了Hooks,它使函数式组件也能具有类组件的生命周期特性。常用的Hooks包括:

  • useState(): 用于在函数式组件中添加state。

  • useEffect(): 在组件渲染后执行副作用操作,类似于componentDidMount和componentDidUpdate的组合。

  • useContext(): 用于在函数式组件中获取上下文对象。

  • useReducer(): 类似于Redux的reducer,用于复杂的state逻辑。

  • useCallback()和useMemo(): 用于性能优化,避免在每次渲染时重新创建函数或计算。

相关推荐
bysking17 分钟前
【前端-组件】定义行分组的表格表单实现-bysking
前端·react.js
王哲晓33 分钟前
第三十章 章节练习商品列表组件封装
前端·javascript·vue.js
fg_41136 分钟前
无网络安装ionic和运行
前端·npm
理想不理想v38 分钟前
‌Vue 3相比Vue 2的主要改进‌?
前端·javascript·vue.js·面试
酷酷的阿云1 小时前
不用ECharts!从0到1徒手撸一个Vue3柱状图
前端·javascript·vue.js
微信:137971205871 小时前
web端手机录音
前端
齐 飞1 小时前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
神仙别闹1 小时前
基于tensorflow和flask的本地图片库web图片搜索引擎
前端·flask·tensorflow
GIS程序媛—椰子2 小时前
【Vue 全家桶】7、Vue UI组件库(更新中)
前端·vue.js
DogEgg_0012 小时前
前端八股文(一)HTML 持续更新中。。。
前端·html