React 组件的生命周期详解

本文详细解析了React组件的生命周期,包括创建阶段的componentWillMount、render和componentDidMount,运行阶段的componentWillReceiveProps、shouldComponentUpdate、componentWillUpdate、render和componentDidUpdate,以及销毁阶段的componentWillUnmount。此外,还提到了defaultProps的初始化和组件生命周期中可以调用this.setState()的时机。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.概念

在组件创建、到加载到页面上运行、以及组件被销毁的过程中,总是伴随着各种各样的事件,这些在组件特定时期,触发的事件,统称为 组件的生命周期;

组件生命周期分为三部分:

  • 组件创建阶段:组件创建阶段的生命周期函数,有一个显著的特点:创建阶段的生命周期函数,在组件的一辈子中,只执行一次;
    • componentWillMount:组件将要被挂载,此时还没有开始渲染虚拟DOM。

    • render: 第一次开始渲染真正的虚拟DOM,当render执行完,内存中就有了完整的虚拟DOM了。

    • componentDidMount:组件完成了挂载,此时组件已经显示在页面上了,当执行完这个方法,组件就进入运行中状态。

  • 组件运行阶段:也有一个显著的特点,根据组件的state和props的改变,有选择性的触发0次或多次;
    • componentWillReceiveProps:组件将要接收新属性,此时,只要这个方法被触发,就证明父组件向当前子组件传递新的属性值;
    • shouldComponentUpdate:组件是否需要被更新(返回true|false控制组件是否更新),此时,组件页面尚未被更新,但是,state和props是最新的。
    • componentWillUpdate:组件将要被更新,内存中的虚拟DOM树还是旧的,即页面还是没有更新。
    • render:根据最新的state和props重新渲染一棵内存中的虚拟DOM树,,当render调用完毕,内存中的旧虚拟DOM树,已经被新的DOM树替换,但此时页面仍然是旧的。
    • componentDidUpdate:页面是最新的,state、虚拟DOM树、页面已经完全保持同步。
  • 组件销毁阶段:也有一个显著的特点,一辈子只执行一次;
    • componentWillUnmount:组件将要被卸载,此时组件还是可以正常使用。
2.React Native组件生命周期图:

在这里插入图片描述

生命周期图分析:

defaultProps

在组件创建之前,会先初始化默认的props属性,这是全局调用一次,严格地来说,这不是组件的生命周期的一部分。在组件被创建并加载候,首先调用 constructor 构造器中的 this.state = {},来初始化组件的状态。

在这里插入图片描述

在组件生命周期中,每个生命周期函数调用的次数不同;同时,在某些生命周期可以调用this.setState()还更改state,那么有哪些可以执行this.setState()呢?

在这里插入图片描述
组件生命周期的执行顺序:

  • 组件创建阶段:

    • constructor()

    • componentWillMount()

    • render()

    • componentDidMount()

  • 组件运行阶段:

    • componentWillReceiveProps(nextProps)
    • shouldComponentUpdate(nextProps, nextState)
    • componentWillUpdate(nextProps, nextState)
    • render()
    • componentDidUpdate(prevProps, prevState)
  • 组件销毁阶段:

    • componentWillUnmount()

有nextProps、nextState说明在该生命周期中直接通过this.state或this.props获取的值还是上一次未更新的值,可通过nextProps或nextState在该生命周期获取最新状态或属性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值