当程序可以运行,一个组件的生命周期函数运行流程
挂载阶段:
componentWillMount: 组件将要挂载时执行,此时可以获取到this.state,this.props,但是获取不到DOM元素
render:render表示虚拟DOM开始构建,但是此时还没有开始挂载,注意的是在render中不能修改state,否则容易导致爆栈,当return结束后,表示此时虚拟DOM构建完毕
componentDidMount: 此时组件挂载完毕,此时可以通过document.getElementById(id)等方法获取到DOM元素,此时表示程序挂载完成,开始进入运行阶段
运行阶段:
componentWillReceiveProps:父组件改变传递参数时执行,接收一个参数,为最新的props,注意点:组件第一次渲染时得到父组件传值时,该生命周期函数不会被调用;
shouldComponentUpdate:,当数据发生改变时触发,只能返会Boolean值,true:表示渲染页面,false:表示不渲染页面,可以接收两个参数,shouldComponentUpdate(nextProps, nextStates){}
表示改变后的props和state,如果通过this.props和this.state拿到的是未改变之前的值
componentWillUpdate:页面将要更新时执行,此时还未更新;接收的参数和shouldComponentUpdate相同
render: 再次构建虚拟DOM,
componentDidUpdate: 页面更新完成,接收两个参数,componentDidUpdate(nextProps, nextStates){},这两个参数分别是未更新之前的props和state。
销毁阶段:
componentWillUnmount: 组件将要销毁执行
本文详细介绍了React组件的生命周期,从挂载阶段的componentWillMount、render到componentDidMount,再到运行阶段的componentWillReceiveProps、shouldComponentUpdate、componentWillUpdate、render和componentDidUpdate,最后是销毁阶段的componentWillUnmount。每个阶段的关键行为和使用场景都有所阐述,帮助开发者理解组件在不同阶段如何响应变化和更新。
786

被折叠的 条评论
为什么被折叠?



