React的生命周期实例分析


这篇文章主要讲解了“React的生命周期实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React的生命周期实例分析”吧!React 生命周期分为三种状态1. 初始化2.更新3.销毁1、getDefaultProps()设置默认的props,也可以用dufaultProps设置组件的默认属性.2、getInitialState()在使用es6的class语法时是没有这个钩子函数的,可以直接在constructor中定义this.state。此时可以访问this.props3、componentWillMount()组件初始化时只调用,以后组件更新不调用,整个生命周期只调用一次,此时可以修改state。在渲染前调用,在客户端也在服务端。4、 render()react最重要的步骤,创建虚拟dom,进行diff算法,更新dom树都在此进行。此时就不能更改state了。5、componentDidMount()组件渲染之后调用,只调用一次。在第一次渲染后调用,只在客户端。之后组件已经生成了对应的DOM结构,可以通过this.getDOMNode()来进行访问。如果你想和其他JavaScript框架一起使用,可以在这个方法中调用setTimeout,setInterval或者发送AJAX请求等操作(防止异步操作阻塞UI)。6、componentWillReceiveProps(nextProps)组件初始化时不调用,组件接受新的props时调用。使用componentWillReceiveProps的时候,不要去向上分发,调用父组件的相关setState方法,否则会成为死循环在组件接收到一个新的prop (更新后)时被调用。这个方法在初始化render时不会被调用。7、shouldComponentUpdate(nextProps, nextState)react性能优化非常重要的一环。组件接受新的state或者props时调用,我们可以设置在此对比前后两个props和state是否相同,如果相同则返回false阻止更新,因为相同的属性状态一定会生成相同的dom树,这样就不需要创造新的dom树和旧的dom树进行diff算法对比,节省大量性能,尤其是在dom结构复杂的时候返回一个布尔值。在组件接收到新的props或者state时被调用。在初始化时或者使用forceUpdate免费云主机域名时不被调用。可以在你确认不需要更新组件时使用。8、componentWillUpdata(nextProps, nextState)组件初始化时不调用,只有在组件将要更新时才调用,此时可以修改state9、render()组件渲染10、componentDidUpdate()组件初始化时不调用,组件更新完成后调用,此时可以获取dom节点。11、componentWillUnmount()组件将要卸载时调用,一些事件监听和定时器需要在此时清除。只执行一次: constructor、componentWillMount、componentDidMount执行多次:render 、子组件的componentWillReceiveProps、componentWillUpdate、componentDidUpdate有条件的执行:componentWillUnmount(页面离开,组件销毁时)不执行的:根组件(ReactDOM.render在DOM上的组件)的componentWillReceiveProps(因为压根没有父组件给传递props)componentWillMount组件挂载之前render组件的渲染方法componentDidMount组件挂载完成执行componentWillReceiveProps触发条件1. 当一个组件从父组件接收了参数。2.如果这个组件第一次被父组件加载的时候不会被执行。3.这个组件之前已经存在于父组件中,并且接收的数据发生变动这时此方法才会被触发。shouldComponentUpdata:是否要更新数据?需要一个返回值true继续执行下面的生命周期,false就会终止当前组件数componentWillUpdate:组件将要更新render:组件的重新渲染componentDidUpdata:组件完成更新componentWillUnmount:组件销毁的时候触发感谢各位的阅读,以上就是“React的生命周期实例分析”的内容了,经过本文的学习后,相信大家对React的生命周期实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: springboot数据库查询时出现时区差异问题怎么解决

今天小编给大家分享一下springboot数据库查询时出现时区差异问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最近项目中使用到多数…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/16 15:21
下一篇 03/16 15:22

相关推荐