组件生命周期(React16之前)
每个生物😯都有它的生命周期,从出生🐣、少年、成年再到死亡。同理组件也有它特定的生命周期,React用不同的方法来描述它的整个生命周期。现在,要稍微修改一下组件的代码,当组件加载完毕1秒以后,使
like
的值自动加1
componentDidMount
这个方法就是在render
完成并且组件装载完成之后调用的方法,所以界面中先显示为0,1秒以后此方法被调用,界面被重新渲染,like
值变成了1
1.组件首次加载
constructor
getInitialState
只会在装载之前调用一次,这个函数的返回值会被设置到this.state
中,需要注意的是,在ES6的写法,只需写在constructor
中即可(ES5)getDefaultProps
只会在装载之前调用一次,在组件中赋值的数据会被设置到this.props
中。(ES5)
defaultProps
赋值指定props初始,在ES6写法中应用,如下
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
,在组件被卸载和销毁之前调用的方法,可以在这里做一些清理的工作。
生命周期详情
生命周期流程
探索
BodyIndex
的componentWillMount
和componentDidMount
生命周期
在浏览器的开发者工具中就可以看到
console
再来查看Index的的
componentWillMount
和componentDidMount
生命周期,BodyIndex
包含在Index
中
所有生命周期尝试
最后更新于