[三元学React]React组件的生命周期函数

栏目: IOS · Android · 发布时间: 4年前

内容简介:生命周期函数指在某一个时刻组件会自动调用执行的函数问题:constructor是不是生命周期函数?constructor也是组件在某一个时刻会调用的方法,但是它是ES6语法的一部分,并不是react组件的特性,因此不算作react组件的生命周期函数。

生命周期函数指在某一个时刻组件会自动调用执行的函数

问题:constructor是不是生命周期函数?

constructor也是组件在某一个时刻会调用的方法,但是它是ES6语法的一部分,并不是react组件的特性,因此不算作react组件的生命周期函数。

二、生命周期流程

[三元学React]React组件的生命周期函数

1、Initialization

首先是Initialization,初始化state和props的数据,在constructor函数中会接收props、初始化state和一些方法。如:

constructor(props) {
    super(props);
    this.state = { 
        inputValue: '',
        list: []
    }
    this.handleBtnClick = this.handleBtnClick.bind(this)
}
复制代码

2、Mounting

然后是组件的挂载阶段。

什么是挂载?挂载是组件第一次被放到页面上的时候。

(1)componentWillMount()

在组件即将被挂载到页面的时候自动执行

(2)render()

组件挂载阶段

(3)componentDidMount()

组件挂载到页面之后执行

注意: componentWillMount和componentDidMount在组件的生命周期执行一次

3、Updation

更新包括props的更新和state的更新。 两者具有一些共同的生命周期钩子。

(1)shouldComponentUpdate()

组件在更新前,会自动被执行,这个钩子函数返回一个布尔值,来决定组件之后是否被更新。

(2)componentWillUpdate()

在组件更新之前,它会自动执行,但是他在shouldComponentUpdate之后执行。 如果shouldComponentUpdate返回true,它会执行,否则不会执行。

(3)render()

将新虚拟DOM与原来的进行比对(diff),然后修改真实DOM。

(4)componentDidUpdate()

组件更新之后立即执行。

(props更新特有)componentWillRecieveProps

不过props更新了会另外执行一个生命周期函数componentWillRecieveProps,那么它在什么时候执行呢?

如果一个组件从父组件接受了数据,只要父组件的render函数被 重新 执行了,那么这个componentWillRecieveProps才会被执行。这个生命周期函数不是太常用。

4、Unmounting

componentWillUnmount()

在组件即将被移除的时候执行。

三、生命周期函数的使用场景

1、避免子组件不必要的重新渲染

当父组件的状态发生改变时,会自动调用render函数,从而调用子组件的render函数,但是在有些时候父组件这些改变的状态和子组件没有关系,因此子组件没有必要重新调用render,浪费浏览器性能。怎么解决这个问题?

很简单,在子组件的shouldComponentUpdate这里拦截一下, 如下:

//接受两个参数,分别是新传进来的props和state
shouldComponentUpdate(nextProps, nextState) {
    //进行相关变量的比对,如果不一样则更新
    if(nextProps.xxx !== this.props.xxx){
        return true;
    }
    return false;
    //也可以简化为:
    //return nextProps.xxx !== this.props.xxx ? true : false;
}
复制代码

2、发送Ajax请求

最好在componentDidMount里面发送Ajax请求。一般而言Ajax数据只需要获取一次即可,那么为什么不放在componentWillMount和render函数里面呢?

如果放在componentWillMount里面,以后如果用到了ReactNative或者服务端同构,会和其他的技术产生冲突,这里不做深入。

如果放在render函数里面,事实上render在组件的生命周期中是经常被执行的,那么这个请求也会发送非常多次,也并不合理。

发送请求案例如下:

import axios from 'axios'
//省略1000行代码
componentDidMount() {
    axios.get('/api/data')
        .then(() => {})
        .catch(() => {})
}
复制代码

之前是Vue选手,现在来学React,小小的总结,希望能帮助大家。


以上所述就是小编给大家介绍的《[三元学React]React组件的生命周期函数》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

About Face 4: 交互设计精髓

About Face 4: 交互设计精髓

[美] 艾伦·库伯、[美] 罗伯特·莱曼、[美] 戴维·克罗宁、[美] 克里斯托弗·诺埃塞尔 / 倪卫国、刘松涛、杭敏、薛菲 / 电子工出版社 / 2015-10 / 118.00元

《About Face 4: 交互设计精髓》是《About Face 3:交互设计精髓》的升级版,此次升级把全书的结构重组优化,更加精练和易用;更新了一些适合当下时代的术语和实例,文字全部重新编译,更加清晰易读;增加了更多目标导向设计过程的细节,更新了现行实践,重点增加 移动和触屏平台交互设计,其实《About Face 4: 交互设计精髓》多数内容适用于多种平台。 《About F......一起来看看 《About Face 4: 交互设计精髓》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具