在componentWillMount中执行this.setState是不会触发二次渲染的。es6
它也只会在挂载过程当中被调用一次,它的做用和constructor没有太大差别。有不少人在componentWillMount中请求后台数据,认为这样能够更早的获得数据,componentWillMout是在render函数执行前执行的,虽然请求是在第一次render以前发送的,可是返回并不能保证在render以前完成。render不会等你慢慢请求.因此在渲染的时候没有办法等到数据到来再去setState触发二次渲染.异步
仔细思考一下,componentWillMount好像没啥卵用了。正所谓存在即合理,在服务端渲染的场景中componentDidMount是不会被执行的,所以能够在componnetWillMount中发生AJAX请求。函数
顺便说一句在es6中,使用extend component的方式里的constructor函数和componentWillMount是通用的做用,因此你在构造函数里初始化了组件的状态就没必要在WillMount作重复的事情了.this
React中不推荐在componentWillMount中发送异步请求。spa
componentDidMount呢?这个生命周期函数在是在render以后调用一次,component已经初始化完成了.3d
在生产时,componentDidMount生命周期函数是最好的时间去请求数据,其中最重要缘由:使用componentDidMount第一个好处就是这个必定是在组件初始化完成以后,再会请求数据,所以不会报什么警告或者错误,咱们正常请教数据完成以后通常都会setState.component