react生命周期(一分钟秒懂)

毫不夸张的说,react的生命周期搞清楚了,react就会了一半。

实例化

首次实例化

  • getDefaultProps
  • getInitialState
  • componentWillMount
  • render
  • componentDidMount 实例化之后更新,这一过程和上面一样,但没有getDefaultProps这个过程 简单记忆:props => state => mount => render => mounted

存在期

组件已经存在,状态发生改变时

  • componetWillReceiveProps
  • shouldComponentUpdate
  • ComponentWillUpdate
  • render
  • componentDidUpdate

销毁期

  • componentWillUnmount

生命周期中10个API的作用说明

  • getDefaultProps 作用于组件类,只调用一次,返回对象用于设置默认的props,对于引用值,会在实例中共享

  • getInitialState 作用于组件实例,在实例创建时调用一次,用于初始化每个实例的state,此时可以访问this.props

  • componentWillMount 在完成首次渲染之前调用,此时可以修改组件的state

  • render 必选方法,创建虚拟DOM,该方法具有特殊规则:

  • 只能通过this.props 和this.state访问数据

  • 可以返回null、false或任何React组件

  • 只能出现一个顶级组件,数组不可以

  • 不能改变组件的状

  • 不能修改DOM

  • componentDidMount 真实的DOM被渲染出来后调用,可以在此方法中通过 this.getDOMNode()访问真实的DOM元素。此时可以使用其它类库操作DOM。服务端不会被调用

  • componetWillReceiveProps 组件在接收到新的props时调用,并将其作为参数nextProps使用,此时可以更改组件的props及state

  • shouldComponentUpdate 组件是否应当渲染新的props或state,返回false表示跳过后续的生命周期方法,通常不需要使用以避免出现bug。在出现应用性能瓶颈时,是一个可以优化的点。

  • componetWillUpdate 接收新props或state后,进行渲染之前调用,此时不允许更新props或state

  • componetDidUpdate 完成渲染新的props或state之后调用 ,此时可以访问DOM元素。

  • componetWillUnmount 组件被移除之前调用,可以用于做一些清理工作,在componentDidMount方法中添加的所有任务都需要在该方法中撤销,比如创建的定时器或添加的事件监听器。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 做React需要会什么? react的功能其实很单一,主要负责渲染的功能,现有的框架,比如angular是一个大而...
    苍都阅读 14,850评论 1 139
  • 本笔记基于React官方文档,当前React版本号为15.4.0。 1. 安装 1.1 尝试 开始之前可以先去co...
    Awey阅读 7,831评论 14 128
  • 使用 create-react-app 快速构建 React 开发环境 项目的目录结构如下: React JSX ...
    majun00阅读 535评论 0 0
  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,882评论 1 18
  • 和妈妈刚刚聊到男朋友。看看我们现在学校里很多人都有了女朋友啊,男朋友啊,但是说真的,我并不觉得那样很好。不...
    山榛隰苓阅读 248评论 0 0