React组件的生命周期

React 组件的生命周期根据广义定义描述,可以分为mount、updating和unmount这几个阶段。当渲染后的组件需要更新时,我们会重新去渲染组件,直至卸载。下面是针对React16.4版本的一张组件生命周期图(详见网址 http://projects.wojtekmaj.pl/react-lifecycle-methods-diagram/ ):

下面分别对各个生命周期方法进行说明:

1. constructor方法

   方法签名:constructor(props)

   作用:用于组件内部的state初始化、事件方法的绑定,

   注意事项:(1) 方法内的第一句应为 super(props) ,这样可以避免构造方法后面的代码使用this.props时出现undefined错语

     (2)在构造方法内对state应直接进行赋值,而不应调用setState()方法

       (3) 避免拷贝props到state中,而要用this.props.xxx , 否则当props发生变化时,state将不能得到及时更新

    示例:  

constructor(props) {
    super(props);
    this.state = {date: new Date()};
    this.stop = this.stop.bind(this);
    this.update = this.update.bind(this);
  }

 

2. getDerivedStateFromProps方法

    方法签名:static getDerivedStateFromProps(props, state)

    作用:它允许组件根据props的变化而更新其内部state。如果要更新state,该方法必须返回新的state(称之为派生state),或者返回null代表不更新。这个生命周期方法在render方法执行之前被调用,当组件在mount和updating时都会执行该方法。

     注意事项:

              (1) 在组件的生命周期中,派生state应该谨慎使用,应当在满足当props改变并符合一定的条件时再对state进行更新

    (2) 当组件的setState方法和forceUpdate方法被调用时,也会触发该生命周期方法。

     示例 :

static getDerivedStateFromProps(props, state){
    var date = props.date;
if(true) //满足一定条件   
return {date: date} ; }

 

3. shouldComponentUpdate方法

   签名:shouldComponentUpdate(nextProps, nextState)

   作用:该生命周期方法决定当组件的props和state发生改变时,是否需要重新渲染组件。该方法默认情况下返回true,表示需要重新渲染,可以通过返回false阻止组件的向下的生命周期方法的执行。该生命周期方法应该仅作为性能优化的手段去使用,而避免用于其他用途。

   例如当父组件的props发生变化时,我们希望只是重新渲染受影响的一部分节点,如下图:

    

   注意事项:

          (1)当组件的props发生改变或者setState方法执行后会触发该生命周期方法的调用。

          (2) 在组件的mount阶段和forceUpdate()方法执行后,不会触发该生命周期方法调用。

          (3)可以考虑让组件继承React.PureComponent,  其已经实现了React.PureComponent方法,不过它的实现是对当props和state和nextProps和nextState的浅层比较

 

4. getSnapshotBeforeUpdate方法

   签名:getSnapshotBeforeUpdate(prevProps, prevState)

   作用:该方法在render方法之后,在render的输出到DOM之前执行。在这个生命周期方内允许组件可以从DOM上捕获一些信息(例如 scroll position),该方法返回的任何值都将作为参数(后称快照值)传递给componentDidUpdate()生命周期方法。该方法要么返回一个快照值或者null 。

   示例:这个方法的使用场景,比如一个聊天窗口,当用户发出新的聊天信息后,可能需要根据情况滚动窗口

 

 

 

posted @ 2018-07-24 11:38  杭州胡欣  阅读(1473)  评论(0编辑  收藏  举报