美文网首页
React生命周期

React生命周期

作者: 未路过 | 来源:发表于2022-11-11 09:20 被阅读0次
image.png image.png image.png 在render函数里面,每使用一次 image.png

先经过babel,进行React.createElment的包裹,然后被react和react-dom执行。
createElement函数就会根据类创建一个实例。(App是一个类,)
React.createElement(App, null)
而且每次创建实例的时候,就会先执行类的constructor方法。然后执行实例render方法。返回一个react element的一个元素。然后转换成真实dom,挂载到元素上。渲染到界面上。
然后执行componentDidMount实例方法。
我们通过setState修改数据的时候,会根据新的state数据
会重新执行实例方法的render函数,渲染出来最新的数据。
(注意:setState方法就算里面的state没有发生变化,也会重新渲染界面。)


image.png
image.png
image.png

https://zh-hans.reactjs.org/docs/react-component.html

image.png

在componentDidUpdate之前会先执行getSnapshotBeforeUpdate,在React更新DOM之前回调的一个函数,这个是在更新dom之前执行的,所以获取dom更新之前的一些数据,在这里做一个保存。
;然后更新dom,dom更新完以后,调用componentDidUpdate。

在getSnapshotBeforeUpdate里面可以保存一些旧的数据。

  getSnapshotBeforeUpdate() {
    return {
      useScroll: 1000,
    };
    //这里返回的东西在componentDidUpdate是可以拿到的
  }
  componentDidUpdate(prevPros, prevState, snapsshot) {
    console.log(prevPros, prevState);
//{} {message: 'hello world', isShowMessage: true}
    console.log(snapsshot); //{useScroll: 1000}
    console.log("app did update");
  }

相关文章

  • 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/gujbtdtx.html