组件生命周期(React16之前)

  • 每个生物😯都有它的生命周期,从出生🐣、少年、成年再到死亡。同理组件也有它特定的生命周期,React用不同的方法来描述它的整个生命周期。现在,要稍微修改一下组件的代码,当组件加载完毕1秒以后,使like的值自动加1

...
componentDidMount(){
  setTimeout(()=>{
    this.likeCallback();
  },1000);
}
...
  • componentDidMount这个方法就是在render完成并且组件装载完成之后调用的方法,所以界面中先显示为0,1秒以后此方法被调用,界面被重新渲染,like值变成了1

1.组件首次加载

  • constructor

  • getInitialState只会在装载之前调用一次,这个函数的返回值会被设置到this.state中,需要注意的是,在ES6的写法,只需写在constructor中即可(ES5)

  • getDefaultProps只会在装载之前调用一次,在组件中赋值的数据会被设置到this.props中。(ES5)

const Sample = React.createClass({
  getInitalstate:function (){
    return {name:'tyrmars'};
  },
  getDefaultProps:function (){
    return {sampleProps: 0}
  }
})
  • defaultProps赋值指定props初始,在ES6写法中应用,如下

class Sample extends React.Component{
  constructor(props){
    super(props);
    this.state = {name:'tyrmars'}
  }
};

Sample.defaultProps = {
  sampleProps: 0
}
  • componentWillMount在render之前被调用,可以在渲染之前做一些准备工作。

  • render这个方法是组件的一个必要方法。当这个方法被调用的时候,应返回一个ReactElement对象。render是一个纯函数,它的意义就是在给定相同的条件时,它的🔙返回结果应该每次都完全一致的。不应该有任何修改组件state的代码或者修改组件state 的代码或者是和浏览器交互的情况。

  • componentDidMount只会在装载完成之后调用一次,在render之后调用,从这里开始获取组件的DOM结构。如果想让组件加载完毕后做一些额外的操作(比如AJAX请求等),可以在这个方法中添加相应代码。

2.组件props更新

  • 当组件接收到新的props的时候,会依次触发下列方法。

    • componentWillReceiveProps(object nextProps),在组件接收到新的props的时候被触发,参数nextProps就是传入的新的props,你可以用它和this.props比较,来决定是否用this.setState实现UI重新渲染。

    • shouldCompentUpdate,在重新render之前被调用,可以返回一个布尔值来决定一个组件是否更新,如果返回false,那么前面的流程都不会被触发。这个方法默认的返回值都是true

    • render,和组件首次加载的方法相同

    • componentDidUpdate,重新渲染完成以后立即调用,和componentDidMount类似

3.组件卸载

  • componentWillUnmount,在组件被卸载和销毁之前调用的方法,可以在这里做一些清理的工作。

生命周期详情

生命周期流程

  • 探索BodyIndexcomponentWillMountcomponentDidMount生命周期

import React from 'react';
export default class BodyIndex extends React.Component{
  componentWillMount(){
    //定义你的逻辑即可
    console.log("BodyIndex - componentWillMount");
  }

  componentDidMount(){
    console.log("BodyIndex - componentDidMount");
  }
  render(){
    ...
    return(
      ...
    )
  }
}
  • 在浏览器的开发者工具中就可以看到console

  • 再来查看Index的的componentWillMountcomponentDidMount生命周期,BodyIndex包含在Index

var React = require('react');
var ReactDOM = require('react-dom');
import CompomentHeader from './components/header';
import CompomentFooter from './components/footer';
import BodyIndex from './components/bodyIndex';
class Index extends React.Component {
  componentWillMount(){
    //定义你的逻辑即可
    console.log("Index - componentWillMount");
  }
  componentDidMount(){
    console.log("Index - componentDidMount");
  }
  render() {
    return (
      <div>
      <CompomentHeader/>
      <BodyIndex/>
      <CompomentFooter/>
      </div>
    )
  }
}

// 入口
ReactDOM.render( <Index /> , document.getElementById('example'));

所有生命周期尝试

import React from 'react';
import {Button,List} from 'antd-mobile';

class App extends React.Component {
  render(){
    const boss = 'JavaScript';
    return (
      <div>
        <h1>React is {boss}</h1>
        <First use='React'/>
      </div>
    )
  }
}

class First extends React.Component {
  constructor(){
    super();
    this.state = {
      things:['C++','PHP','Python']
    }
  }
  componentWillMount(){
    console.log('组件马上开始加载');
  }
  componentDidMount(){
    console.log('组件加载完毕');
  }
  componentWillReceiveProps(){
    console.log('组件要接受父组件的值');
  }
  shouldComponentUpdate(){
    console.log('判断是不是要更新组件');
    return true;
  }
  componentWillUpdate(){
    console.log('马上要更新组件了');
  }
  componentDidUpdate(){
    console.log("组件更新完毕");
  }
  componentWillUnmount(){
    console.log('组件卸载');
  }
  addthings(){
    console.log('hello world');
    this.setState({
      things:[...this.state.things,'love'+ Math.random()]
    })
  }
  render(){
    console.log('组件加载');
    return (
      <div>
        <h2>Component is {this.props.use}</h2>
        <Button type='primary' onClick={()=>this.addthings()}>hello</Button>
        <Rd list = 'Router'/>
        <List renderHeader={()=>'语言列表'}>{this.state.things.map(v=><List.Item key={v}>{v}</List.Item>)}</List>
      </div>
    );
  }
}

function Rd(props) {
  return (
    <div>
      <h3>Redux and {props.list}</h3>
    </div>
  );
}

export default App;

最后更新于