React-class组件生命周期

在组件特定时期,触发的条件,统称为生命周期;

  • 组件生命周期分为三部分:
    • 组件创建阶段:组件创建阶段的生命周期函数,有一个显著的特点:创建阶段的生命周期函数,组件一生只执行一次;
      > componentWillMount:组件将要被挂载,此时还没有开始渲染虚拟dom
      > render:第一次开始渲染真正的虚拟dom,当render执行完,内存中就有了完整额虚拟dom了
      > componentDidMount:组件完成了挂载,此时,组件已经显示到了页面上,当这个方法执行完后,组件就进入了运行状态

    • 组件运行状态:也有显著的特点,根据组件的state和props的改变,有选择性的执行0次或多次
      > componentWillReceiveProps:组件将要接受新的属性,此时,只要这个方法被触发,就证明父组件为当前子组件传递了新的参数
      > shouldComponentUpdate:组件是否需要被更新,此时,组件尚未被更新,但是,state和props肯定是最新的
      > componentWillUpdate:组件将要被更新,此时,尚未开始更新,内存中的虚拟dom树还是旧的
      > render:此时又要重新根据最新的state和props重新渲染一颗内存中的虚拟dom树,当render调用完毕后,内存中的旧DOM树替换了!此时页面还是旧的
      > ComponentDidUpdate:此时,页面又被重新渲染了,state和虚拟DOM和页面数据已经完全保持同步

    • 组件销毁阶段:一生只执行一次
      > componentWillUnmount:组件将要被卸载,此时组件还可以正常使用;

原文地址:https://www.cnblogs.com/codeskys/p/12952881.html