美文网首页
组件的生命周期(Component Lifecycle)

组件的生命周期(Component Lifecycle)

作者: 冷洪林 | 来源:发表于2017-01-09 11:03 被阅读84次

在iOS中UIViewController提供了(void)viewWillAppear:(BOOL)animated, - (void)viewDidLoad,(void)viewWillDisappear:(BOOL)animated等生命周期方法,在Android中Activity则提供了onCreate(),onStart(),onResume(),onPause(),onStop(),onDestroy()等生命周期方法,这些生命周期方法展示了一个界面从创建到销毁的一生。

那么在React 中组件(Component)也是有自己的生命周期方法的。

组件的生命周期分成三个状态:

  • Mounting:已插入真实 DOM
  • Updating:正在被重新渲染
  • Unmounting:已移出真实 DOM

心得:你会发现这些React 中组件(Component)的生命周期方法从写法上和iOS中UIViewController的生命周期方法很像,React 为每个状态都提供了两种处理函数,will 函数在进入状态之前调用,did 函数在进入状态之后调用。

Mounting(装载)

  • getInitialState(): 在组件挂载之前调用一次。返回值将会作为 this.state 的初始值。
  • componentWillMount():服务器端和客户端都只调用一次,在初始化渲染执行之前立刻调用。
  • componentDidMount():在初始化渲染执行之后立刻调用一次,仅客户端有效(服务器端不会调用)。

Updating (更新)

  • componentWillReceiveProps(object nextProps) 在组件接收到新的 props 的时候调用。在初始化渲染的时候,该方法不会调用。

用此函数可以作为 react 在 prop 传入之后, render() 渲染之前更新 state 的机会。老的 props 可以通过 this.props 获取到。在该函数中调用 this.setState() 将不会引起第二次渲染。

  • shouldComponentUpdate(object nextProps, object nextState): 在接收到新的 props 或者 state,将要渲染之前调用。

该方法在初始化渲染的时候不会调用,在使用 forceUpdate 方法的时候也不会。如果确定新的 props 和 state 不会导致组件更新,则此处应该 返回 false。

心得:重写次方你可以根据实际情况,来灵活的控制组件当 props 和 state 发生变化时是否要重新渲染组件。

  • componentWillUpdate(object nextProps, object nextState):在接收到新的 props 或者 state 之前立刻调用。

在初始化渲染的时候该方法不会被调用。使用该方法做一些更新之前的准备工作。

注意:你不能在该方法中使用 this.setState()。如果需要更新 state 来响应某个 prop 的改变,请使用 componentWillReceiveProps。

  • componentDidUpdate(object prevProps, object prevState): 在组件的更新已经同步到 DOM 中之后立刻被调用。

该方法不会在初始化渲染的时候调用。使用该方法可以在组件更新之后操作 DOM 元素。

Unmounting(移除)

  • componentWillUnmount:在组件从 DOM 中移除的时候立刻被调用。

在该方法中执行任何必要的清理,比如无效的定时器,或者清除在 componentDidMount 中创建的 DOM 元素。

相关文章

  • React 组件生命周期

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

  • Component

    简介 Component用于管理拥有运行期状态的组件的生命周期和依赖关系。 创建组件 一个实现了Lifecycle...

  • React 生命周期

    译自 React Component Lifecycle 每个组件都有若干生命周期函数。如函数名称所示,带有wil...

  • 生命周期

    React生命周期 Each component has several "lifecycle methods" ...

  • 组件的生命周期(Component Lifecycle)

    在iOS中UIViewController提供了(void)viewWillAppear:(BOOL)animat...

  • [Android]——架构组件详细介绍

    生命周期感知组件-LifeCycle 1、LifeCycle能够做什么 支持生命周期的组件执行操作以响应另一个组件...

  • Jetpack-Lifecycle

    Lifecycle概述 Lifecycle是生命周期感知型组件,可感知组件(如 Activity、 Fragmen...

  • 【Jetpack日记(2)】Lifecycle的基本使用

    Lifecycle介绍 Lifecycle组件属于Jetpack的架构组件中,它是一个生命周期感知组件安装官方文档...

  • Lifecycle

    Lifecycle 定义 Lifecycle使用 源码中如何使用Lifecycle 定义 构建生命周期感知型组件,...

  • Lifecycle

    Lifecycle 1. Lifecycle的作用 Lifecycle是Jetpack架构组件库中用来感知生命周期...

网友评论

      本文标题:组件的生命周期(Component Lifecycle)

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