温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

react框架的生命周期有哪些阶段

发布时间:2022-02-25 10:04:18 来源:亿速云 阅读:326 作者:iii 栏目:开发技术

这篇文章主要讲解了“react框架的生命周期有哪些阶段”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react框架的生命周期有哪些阶段”吧!

1.挂载卸载过程


(1).constructor():

这个方法是用来完成 React 数据的一个初始化,还接受propscontext这两参数,如果我们想在函数内部使用这两参数时,就必须要使用super()进行传入参数;否则会导致this指向错误。

(2).componentWillMount():

这个方法的话一般比较少用,比较多的是在服务端的时候使用。

(3).componentDidMount():

当组件第一次渲染完成的时候dom节点生成,就可以在这里调用ajax的请求,等到返回setstate数据之后组件会重新的渲染。

(4).componentWillUnmount():

这个方法是用来进行组件的一个卸载和数据的销毁的。有时候我们在执行的时候会碰到下面这个警告,是因为我们的组件中的Ajax请求返回的setstate在我们执行销毁的时候还没有请求完成所报的警告!

Can only update a mounted or mounting component. This usually      means you called setState() on an unmounted component. This is a   no-op. Please check the code for the undefined component.

解决方法如下代码:

componentDidMount() {
    this.isMount === true
    axios.post().then((res) => {
    this.isMount && this.setState({   // 增加条件ismount为true时
      aaa:res
    })
})
}
componentWillUnmount() {
    this.isMount === false
}

2.更新过程


(1).componentWillReceiveProps (nextProps):

这个方法用的比较多的是在接受父组改变之后的props需要重新渲染组件的时候。下面是通过nextPropsthis.props对比,从而重新渲染的代码和注释。

  componentWillReceiveProps (nextProps) {
    nextProps.openNotice !== this.props.openNotice&&this.setState({
        openNotice:nextProps.openNotice
    },() => {
      console.log(this.state.openNotice:nextProps)
      //将state更新为nextProps,在setState的第二个参数(回调)可以打         印出新的state
  })
}

(2).shouldComponentUpdate(nextProps,nextState):

这个方法主要用于在性能部分的优化,还可以通过return false阻止组件的更新。

(3).componentWillUpdate (nextProps,nextState):

在这个方法中,当shouldComponentUpdate返回为true以后呢,组件就会进入重新渲染的流程,进入到这个方法时,我们这个方法里同样可以拿到nextPropsnextState

(4).componentDidUpdate(prevProps,prevState):

这个方法的作用是当组件更新完成之后,react 只有在第一次初始化完成之后会进入componentDidmount;后面的每次重新渲染后都会进入componentDidUpdate(prevProps,prevState)这个生命周期,而且在这个周期中可以拿到prevPropsprevState,就是在更新前的propsstate

(5).render():

render 这个函数会插入 jsx 生成的 dom 结构中,从而生成一份虚拟 dom 树,而且在每一次组件更新时,还会通过其 diff 的算法比较更新前后的 DOM 树,找到最小的而且还有差异的 DOM 节点重新渲染。

感谢各位的阅读,以上就是“react框架的生命周期有哪些阶段”的内容了,经过本文的学习后,相信大家对react框架的生命周期有哪些阶段这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI