美文网首页
React最新的生命周期

React最新的生命周期

作者: 皮神雷卡丘 | 来源:发表于2019-09-29 15:05 被阅读0次

    React 16之后有三个生命周期被废弃(但并未删除)

    componentWillMount
    componentWillReceiveProps
    componentWillUpdate
    官方计划在17版本完全删除这三个函数,只保留UNSAVE_前缀的三个函数,目的是为了向下兼容,但是对于开发者而言应该尽量避免使用他们,而是使用新增的生命周期函数替代它们

    目前React 16.8 +的生命周期分为三个阶段,分别是挂载阶段、更新阶段、卸载阶段

    挂载阶段:

    constructor:
    构造函数,最先被执行,我们通常在构造函数里初始化state对象或者给自定义方法绑定this
    getDerivedStateFromProps:
    static getDerivedStateFromProps(nextProps, prevState),这是个静态方法,当我们接收到新的属性想去修改我们state,可以使用getDerivedStateFromProps
    render:
    render函数是纯函数,只返回需要渲染的东西,不应该包含其它的业务逻辑,可以返回原生的DOM、React组件、Fragment、Portals、字符串和数字、Boolean和null等内容
    componentDidMount:
    组件装载之后调用,此时我们可以获取到DOM节点并操作,比如对canvas,svg的操作,服务器请求,订阅都可以写在这个里面,但是记得在componentWillUnmount中取消订阅

    更新阶段:

    getDerivedStateFromProps:
    此方法在更新个挂载阶段都可能会调用
    shouldComponentUpdate:
    shouldComponentUpdate(nextProps, nextState),有两个参数nextProps和nextState,表示新的属性和变化之后的state,返回一个布尔值,true表示会触发重新渲染,false表示不会触发重新渲染,默认返回true,我们通常利用此生命周期来优化React程序性能
    render: 更新阶段也会触发此生命周期
    getSnapshotBeforeUpdate:
    getSnapshotBeforeUpdate(prevProps, prevState),这个方法在render之后,componentDidUpdate之前调用,有两个参数prevProps和prevState,表示之前的属性和之前的state,这个函数有一个返回值,会作为第三个参数传给componentDidUpdate,如果你不想要返回值,可以返回null,此生命周期必须与componentDidUpdate搭配使用
    componentDidUpdate:
    componentDidUpdate(prevProps, prevState, snapshot),该方法在getSnapshotBeforeUpdate方法之后被调用,有三个参数prevProps,prevState,snapshot,表示之前的props,之前的state,和snapshot。第三个参数是getSnapshotBeforeUpdate返回的,如果触发某些回调函数时需要用到 DOM 元素的状态,则将对比或计算的过程迁移至 getSnapshotBeforeUpdate,然后在 componentDidUpdate 中统一触发回调或更新状态。

    卸载阶段:

    componentWillUnmount:
    当我们的组件被卸载或者销毁了就会调用,我们可以在这个函数里去清除一些定时器,取消网络请求,清理无效的DOM元素等垃圾清理工作。
    react生命周期(http://projects.wojtekmaj.pl/react-lifecycle-methods-diagram/)

    image.png

    相关文章

      网友评论

          本文标题:React最新的生命周期

          本文链接:https://www.haomeiwen.com/subject/ldqwyctx.html