• 【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(): 用于性能优化,避免在每次渲染时重新创建函数或计算。

  • 相关阅读:
    EureKa服务注册与发现(集群部署Eureka与支付模块集群部署、订单模块访问负载均衡调用支付服务实现)
    什么是DNS劫持?如何进行有效应对?
    forplo | 冲冲冲!这个画森林图的包好flexible哦~
    MySQL-基础代码(部分)+思维导图
    【Spring注解】@Conditional注解的使用
    【图像分类】2021-CoAtNet NeurlPS
    基于 Keras 的图像分类器
    CSS(六)定位+元素的显示隐藏
    spring boot项目未将resource目录标志为资源目录导致配置文件无效因而运行报错问题
    自动化运维工具—Ansible
  • 原文地址:https://blog.csdn.net/XiugongHao/article/details/137961938