从vue来到了react,很多相似之处,还好,自我感觉生命周期函数就是个执行过程,生命周期函数(钩子函数)通俗的说就是在某一时刻会被自动调用执行的函数
从React生命周期官方了解
componentWillMount
在渲染前调用,在客户端也在服务端。
componentDidMount
在第一次渲染后调用,只在客户端。之后组件已经生成了对应的DOM结构,可以通过this.getDOMNode()来进行访问。 如果你想和其他JavaScript框架一起使用,可以在这个方法中调用setTimeout, setInterval或者发送AJAX请求等操作(防止异步操作阻塞UI)。
componentWillReceiveProps
在组件接收到一个新的 prop (更新后)时被调用。这个方法在初始化render时不会被调用。
shouldComponentUpdate
返回一个布尔值。在组件接收到新的props或者state时被调用。在初始化时或者使用forceUpdate时不被调用。
可以在你确认不需要更新组件时使用。
componentWillUpdate
在组件接收到新的props或者state但还没有render时被调用。在初始化时不会被调用。
componentDidUpdate
在组件完成更新后立即调用。在初始化时不会被调用。
componentWillUnmount
在组件从 DOM 中移除的时候立刻被调用。
react的生命周期可以分成四个部分:
1.初始化
在这里可以初始化props,state
2.挂载
①:componentWillMount(): 注意:改生命周期在未来17版本中将被弃用(在这里请求异步数据,render可能不会渲染到,因为componentWillMount执行后,render立马执行)
组件被挂载到页面之前调用,整个生命周期中只会调用一次(组件更新时不会再调用)。
注意:在这里可修改state
②:componentDidMount():
组件被挂载到页面之后调用,整个生命周期只调用一次(组件更新不会调用)。
建议:在这里可以异步请求数据。在这里设置状态会触发重新渲染。但是不推荐在这里使用setState函数,它会触发一次额外的渲染,而且是在浏览器刷新屏幕之前执行,用户看不到这个状态。在这里使用setState函数会导致性能问题
3.更新
getDerivedStateFromProps(nextProps,prevState)
新的静态getDerivedStateFromProps生命周期在组件实例化以及接收新props(只要父组件重新渲染,那么这个props不论值是否一样都是一个新的props)后调用。它可以返回一个对象来更新state,或者返回null来表示新的props不需要任何state更新。
getSnapshotBeforeUpdate()
新的getSnapshotBeforeUpdate生命周期在更新之前被调用(例如,在DOM被更新之前)。此生命周期的返回值将作为第三个参数传递给componentDidUpdate。 (这个生命周期不是经常需要的,但可以用于在恢复期间手动保存滚动位置的情况。)
componentWillReceiveProps(nextprops): //注意:此生命周期在未来17版本中将被弃用
组件从父组件中接受了新的props(只要父组件重新渲染,那么这个props不论值是否一样都是一个新的props),并且组件已经存在时调用。(组件初始化时候不调用)。
shouldComponentUpdate(nextprops,nextstate):
组件更新之前调用(组件接受新的props或者state)。函数会返回一个布尔值,true才会更新组件。
注意:最好判断一下新旧两个props/state是否相同,相同则返回false不要触发更新。这样就不用生成新的dom树和旧的进行diff算法对比,从而优化性能。(因为父组件render()调用会使得子组件render()也被执行,引起性能问题)
componentWillUpdate(nextprops,nextstate): //注意:此生命周期在未来17版本中将被弃用
组件更新之前(componentshouldupdate返回true)时调用,组件初始化时不调用
注意:在这里可以更改state,nextstate.xxx = xxx,但是在这里不能调用setState函数,这会导致函数调用componentshouldupdate从而进入死循环。
componentDidUpdate():
组件更新完成之后调用,组件初始化时候不调用。
4.卸载
componentWillUnmount():
组件即将被卸载时执行
注意:在这里清除一些不需要的监听和计时器