美文网首页工作生活
React 生命周期

React 生命周期

作者: succes | 来源:发表于2019-11-29 11:56 被阅读0次

React 16.4 的生命周期图

早期React生命周期图

从图中,我们看到了一些变化

废弃的三个生命周期函数 componentWillMount,componentWillReceiveProps,componentWillUpdate。可以理解为带有Will都被干掉了。

新增方法:

1.getDerivedStateFromProps

React生命周期的命名一直都是非常语意话的,这个生命周期的意思就是从props中获取State。

这个函数是为了替代compontWillReceiveProps存在的,所以在你需要使用componentWillReceiveProps的时候,就可以考虑getDerivedStateFromProps来进行替代 了。

这个函数在每次re-render之前被调用,这意味着你的props没有任何变化,而父state发生了变化,导致子组件发生了re-render,这个生命周期函数依然会被调用。

它是一个静态函数,也就是这个函数不能通过this访问到class属性,也并不推荐直接访问属性。而是通过参数传递提供的nextProps以及preState来进行判断,根据传人的props来映射state。getDerivedStateFromProps 总是需要返回值,返回 null 表示不更新,而componentWillReceiveProps 需要调用setState去更新视图数据

static getDerivedStateFromProps(nextProps, prevState) {

  //根据nextProps和prevState计算出预期的状态改变,返回结果会被送给setState

}


2.getSnapshotBeforeUpdate

该函数会在render之后执行,而执行之时DOM元素还没有被更新,给了一个机会去获取DOM信息,计算得到一个snapshot,这个snapshot会作为componentDidUpdate的第三个参数传入。

getSnapshotBeforeUpdate(prevProps, prevState) {

    console.log('#enter getSnapshotBeforeUpdate');

    return 'foo';

  }

  componentDidUpdate(prevProps, prevState, snapshot) {

    console.log('#enter componentDidUpdate snapshot = ', snapshot);

  }


React生命周期的三个阶段

挂载阶段

constructor()

static getDerivedStateFromProps()

render()

componentDidMount()

更新阶段

static getDerivedStateFromProps()

shouldComponentUpdate()

render()

getSnapshotBeforeUpdate()

componentDidUpdate()

注意:下述方法即将过时,在新代码中应该避免使用他们:

UNSAFE_componentWillUpdate()

UNSAFE_componentWillReceiveProps()

卸载阶段

componentWillUnmount()

错误处理

当渲染过程,生命周期,或子组件的构造函数中抛出错误时,会调用如下方法:

static getDerivedStateFromError()

componentDidCatch()

其他 APIs

setState()

用来设置state的值

在16.3开始,议使用setState的异步函数写法,如:原先我们在使用的时候直接进行赋值:

this.setState({inputValue: e.target.value});

而是使用

This.setState(()=>{ Return { inputValue: value};})

异步方法中,该方法提供了一个回调函数,通过该回调函数,可以确保只有等到setState触法完成之后,才会执行执行回调

this.setState((prevState, nextState)=>{ ... }, callback);

forceUpdate()

调用forceUpdate()的时候,将会跳过ShouldComponent而直接render组件父组件中调用forceUpdate亦会导致自组件的生命周期被触发包括(componentDidUpdate)


为何移除 componentWillUpdate

大多数开发者使用 componentWillUpdate 的场景是配合 componentDidUpdate,分别获取 rerender 前后的视图状态,进行必要的处理。但随着 React 新的 suspense、time slicing、异步渲染等机制的到来,render 过程可以被分割成多次完成,还可以被暂停甚至回溯,这导致 componentWillUpdate 和 componentDidUpdate 执行前后可能会间隔很长时间,足够使用户进行交互操作更改当前组件的状态,这样可能会导致难以追踪的 BUG。

React 新增的 getSnapshotBeforeUpdate 方法就是为了解决上述问题,因为 getSnapshotBeforeUpdate 方法是在 componentWillUpdate 后(如果存在的话),在 React 真正更改 DOM 前调用的,它获取到组件状态信息更加可靠。

除此之外,getSnapshotBeforeUpdate 还有一个十分明显的好处:它调用的结果会作为第三个参数传入 componentDidUpdate,避免了 componentWillUpdate 和 componentDidUpdate 配合使用时将组件临时的状态数据存在组件实例上浪费内存,getSnapshotBeforeUpdate 返回的数据在 componentDidUpdate 中用完即被销毁,效率更高。


问题:

1.为什么componentWillMount被删掉componentDidMount还在?

componentDidMount() 会在组件挂载后(插入 DOM 树中)立即调用。依赖于 DOM 节点的初始化应该放在这里。如需通过网络请求获取数据,此处是实例化请求的好地方。

相关文章

  • React概念图

    React概念图 React组件生命周期概念图 参考文档:React入门教程 组件生命周期React:组件生命周期...

  • React基础篇之组件的生命周期

    引出生命周期 react生命周期(旧) react生命周期(新) getSnapshotBeforeUpdate的...

  • React生命周期

    React v16.0前的生命周期 React v16.4+ 的生命周期图 React v16.9后这些生命周期钩...

  • React v16 生命周期

    React 16 生命周期 React 16.3 新增的生命周期方法 逐渐废弃的生命周期方法: 一般将生命周期分成...

  • 学习并实现react (4)

    实现生命周期 生命周期介绍 React 生命周期图 React 子组件在父组件下的生命周期流程 实现 compon...

  • React面试题 整理脑图

    react基础 React生命周期 react-router react进阶 react Hooks redux 其他

  • react/vue常见问题整理

    一、react 1. react生命周期 react 16生命周期相对于15的变化:componentWillMo...

  • React 组件生命周期

    组件生命周期 参考阅读: component-lifecycle react组件生命周期过程说明 react 组件...

  • 《深入React技术栈》学习笔记Ⅲ

    以下的生命周期都是在 React 15 的生命周期, React 16 的生命周期 API 已经发生变化。Reac...

  • React总结

    [toc] 1.React组件生命周期 1.1 生命周期图 组件的生命周期的图如下: 具体可参考React 组件生...

网友评论

    本文标题:React 生命周期

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