理解React组件的生命周期

简介:

本文作者写作的时间较早,所以里面会出现很多的旧版ES5的时代的方法。不过,虽然如此并不影响读者理解组件的生命周期。反而是作者分为几种不同的触发机制来解释生命周期的各个方法,让读者更加容易理解涉及到的概念。以下是正文。

简介

React在创建组件的时候会触发组件生命周期各个方法的调用。这篇文章就分别介绍其中的各种不同的绘制触发之后调用的各个生命周期的方法。

理解组件的生命周期,你才可以在组件创建、销毁的时候执行特定的方法。甚至于,你可以决定是否更新组件,正确的处理stateprops的改变。

生命周期

要弄清楚生命周期,首先就要区分开初次创建和stateprops更改触发的组件更新,以及组件的卸载。

初始化

初始化
initial props
initial state
componentWillMount
render
componentDidMount

在ES6里,initial props在类的constructor方法里作为参数传入了。initial state则在constructor方法里有开发者自行设置。如:

class DemoComponent extends React.Component {
    constructor(props) {
    super(props)

    this.state = {
        initialState: 'value',
    }

    this._innerMethod = this._innerMethod.bind(this)
  }
}

componentWillMount方法在render方法执行之前被调用。有一点需要注意,在这里设置state不会触发重绘。
render方法返回组件需要的标记(markup),并最终转化为正确的输出。propsstate都不应该在这个方法里修改。一定要记住render方法必须是一个纯函数。也就是每次调用,这个方法都要返回同样的结果。

render方法执行之后就开始执行componentDidMount方法。DOM元素(React Native的原生元素)可以在这个方法里取到。这时可以在这个方法里执行数据获取等操作。如果需要的话,任何的DOM操作都可以在这里执行,绝对不可以在render方法里执行。

State改变引发的绘制

State的修改会触发一些列的方法:

更新state
shouldComponentUpdate
componentWillUpdate
render
componentDidUpdate

shouldComponentUpdate方法会在render方法调用之前调用。在这个方法里可以控制是否绘制组件,或者直接跳过。显然,这个方法一定不会在初始化的时候调用。在这个方法里需要返回一个boolean类型的值,默认返回true

shouldComponentUpdate(nextProps, nextState) {
    return true
}

通过对nextPropsnextState的值的处理,可以判定接下来的重绘是否必要。
componentWillUpdate方法在shouldComponentUpdate方法返回true之后就会被调用。在和方法里任何的this.setState方法调用都是不允许的,因为这个方法是用来为接下来的绘制做准备的,不是用来触发重绘的。

componentDidUpdate方法在render方法之后调用。和componentDidMount方法类似,这个方法里也可以执行DOM操作。

componentWillUpdate(nextProps, nextState) {
    // 为接下来的绘制做准备
}

componentDidUpdate(prevProps, prevState) {
    // 
}

Props改变引发的绘制

任何对props对象的修改也会触发生命周期方法的调用,这个过程和state的修改引发的生命周期方法基本一致,只是多了一个方法。

更新Props
componentWillRecieveProps
shouldComponentUpdate
componentWillUpdate
render
componentDidUpdate

componentWillRecieveProps只会在props对象发生改变并且不是初始绘制的时候调用。在这个方法里,可以根据当前的props和将要传入的props来设置state,但是这样并不会触发绘制。**这个方法里有个很有趣的地方,在这个方法里state的相等比较是无效的,因为state的改变不应该引起任何的props的改变。

componentWillReceiveProps(nextProps) {
    this.setState({
        // 设置state
    })
}

其他的生命周期基本上和改变state引起的生命周期方法是一样的。

卸载

卸载
componentWillUnmount

我们唯一没有触及的方法就是componentWillUnmount了。这个方法在组件被从DOM中移除之前调用。当你需要在组件移除前执行清理操作的时候非常有用。比如,清除timer之类的对象。

原文地址:http://busypeoples.github.io/post/react-component-lifecycle/

欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 572064792 | Nodejs:329118122 做人要厚道,转载请注明出处!
















本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sunshine-anycall/p/6401756.html ,如需转载请自行联系原作者

相关文章
|
3月前
|
前端开发 JavaScript
React 组件生命周期
React 组件生命周期
38 0
|
2月前
|
前端开发 JavaScript
react 组件的生命周期
React组件的生命周期包括从创建到销毁的各个阶段,如挂载(mounting)、更新(updating)和卸载(unmounting)。每个阶段都有特定的方法,用于控制组件的行为和状态,确保高效、有序地渲染和管理UI。
|
4月前
|
前端开发 JavaScript 开发者
介绍一下React生命周期
介绍一下React生命周期
119 9
|
3月前
|
存储 前端开发 JavaScript
深入理解React组件的生命周期与Hooks
【10月更文挑战第7天】深入理解React组件的生命周期与Hooks
172 0
|
5月前
|
前端开发 JavaScript
React 组件的生命周期阶段详解
【8月更文挑战第30天】
57 7
|
4月前
|
前端开发 API UED
React组件生命周期详解
【9月更文挑战第4天】在React应用开发中,掌握组件生命周期对于管理状态和属性至关重要,并能有效提升应用性能。本文详细介绍了React组件生命周期的三个阶段:挂载、更新和卸载,并通过代码示例展示了如何避免状态更新导致的死循环及优化网络请求等问题,帮助开发者构建更高效、可维护的应用。
100 2
|
5月前
|
前端开发 JavaScript
React 组件生命周期方法详解
【8月更文挑战第30天】
73 5
|
5月前
|
前端开发 JavaScript 开发者
React生命周期方法完全指南:深入理解并高效应用每个阶段的钩子——从初始化到卸载的全方位解析
【8月更文挑战第31天】本文详细介绍了React组件生命周期方法,包括初始化、挂载、更新和卸载四个阶段的关键钩子。通过探讨每个阶段的方法,如`componentDidMount`和`componentWillUnmount`,帮助开发者在正确时机执行所需操作,提升应用性能。文章还提供了最佳实践,指导如何避免常见错误并充分利用最新钩子。
135 0
|
5月前
|
前端开发 JavaScript 开发者
React 中的生命周期方法是什么?
【8月更文挑战第31天】
61 0
|
5月前
|
前端开发 JavaScript 开发者
React 组件生命周期的详细描述
【8月更文挑战第24天】
55 0