React生命周期函数理解
一、组件挂载阶段
1. componentWillMount()
该方法在首次渲染之前调用,在一个组件挂载到卸载的过程中,仅仅执行这一次。该函数内可以state初始化的工作,与constructor的作用类似。这里也是在render方法调用前最后一次修改state的方法。
这里不建议使用Ajax获取接口数据,因为是异步的,所以在接下来的第一次render中根本接收不到响应数据。
willMount中setState还是会多一次渲染
2. render()
该方法创建一个虚拟dom,表示组件的输出。(输出可以应用到react-dom,react-native)
3.componentDidMount()
该方法调用时,表明已经渲染出真实的dom,可以在该方法中获取任意节点。
二、组件更新阶段
2.1 父组件状态改变,触发子组件更新(简单说是获取到了新的props)
2.1.1 componentWillReceiveProps(nextProps)
当父级组件state或者props发生改变时,子组件会调用该方法。这里的nextProps和this.props需要我们自己判断是否相同来做出相应的操作。比如根据新的props来setState
2.1.2 shouldComponentUpdate(nextProps, nextState)
当确定组件的props或者state的某种改变不需要重新渲染时,可以通过这个方法返回false来阻止渲染。
2.1.3 componentWillUpdate(nextProps, nextState)
组件得到新的props或者state时,在render前调用该函数。(不要在此方法中更新state)
如果需要相应props的改变时,可以在componentWillReceiveProps中做出响应操作
2.1.4 render
2.1.5 componentDidUpdate(prevProps, prevState)
可以对更新后的dom进行操作
2.2 组件内部状态更新
少了componentWillMount,其他与上面一致
三、卸载
componentWillUnmount()
清除定时器,网络请求等
引用:https://moeover.com/2017/01/17/understand-react-lifecycle.html
React生命周期函数理解的更多相关文章
- React生命周期函数详解
		React生命周期函数 生命周期函数是指在某一个周期自动执行的函数. React中的生命周期执行过程 以下是React中的常用的生命周期函数,按个部分中按照自动执行顺序列出,这几个过程可能存在同时进行 ... 
- 十二、React 生命周期函数
		React生命周期函数: [官方文档]:https://reactjs.org/docs/react-component.html [定义]组件加载之前,组件加载完成,以及组件更新数据,组件销毁. 触 ... 
- react生命周期函数使用箭头函数,导致mobx-react问题
		最近新人加入了项目,遇到了一个很奇怪的问题.mobx observable 属性,onChange的时候就是页面不会刷新. 试来试去,就是不知道什么原因,后来其他同事查到是因为componentWil ... 
- 2.React 生命周期函数
		什么是生命周期函数:在某一时刻组件会自动调用执行的函数. import React,{ Component,Fragment } from 'react' class Note extends Com ... 
- react生命周期函数的应用-----1性能优化 2发ajax请求
		知识点1:每次render其实就会将jax的模板生成一个虚拟dom,跟上一个虚拟dom进行比对,通过diff算法找出不同,再更新到真实dom上去. 1性能优化 每次父组件render一次(除了第一次初 ... 
- react 生命周期函数介绍
		constructor():构造函数 执行:组件加载钱最先调用一次,仅调用一次. 作用:定义状态机变量. 注意:第一个语句必须为super(), 否则会报错:'this' is not allowed ... 
- react生命周期函数
		如图,可以把组件生命周期大致分为三个阶段: 第一阶段:是组件第一次绘制阶段,如图中的上面虚线框内,在这里完成了组件的加载和初始化: 第二阶段:是组件在运行和交互阶段,如图中左下角虚线框,这个阶段组 ... 
- react  生命周期函数的一些心得体会
		一.理论 组件本质上是状态机,输入确定,输出一定确定 生命周期的三个阶段,三者时间是不固定的,只是在逻辑上的分类: 二.初始化阶段: getDefaultProps:获取实例的默认属性(即使没有生成实 ... 
- 说一说我了解的react生命周期函数
		我了解的几个阶段 Mounting 挂载 Updating 更新 Unmounting 卸载 我说几个我常用的钩子函数 1.挂载阶段Mounting 1)constructor():函数构造器 执行次 ... 
随机推荐
- CentOS7 升级 Python2.x 到 Python3.x
			CentOS 7 中默认安装了 Python,版本比较低(2.7.5),为了使用新版 3.x,需要对旧版本进行升级.由于很多基本的命令.软件包都依赖旧版本,比如:yum.所以,在更新 Python 时 ... 
- js - 原生ajax访问后台读取数据并显示在页面上
			1.前台调用ajax访问后台方法,并接收数据 <%@ page contentType="text/html;charset=UTF-8" language="ja ... 
- 学习LayUI时自研的表单参数校验框架
			开发背景&痛点:每次写前端的表单的时候需要对表单里用户填写的内容进行校验,减少服务器压力,提前对已知错误对用户提示.每次会要写很多的if else等等对输入框中的内容进行判断,并对为空.格式不 ... 
- 树状数组(binary index  tree)
			概述 修改和查询复杂度为log(n)的数据结构,所有奇数位的数和原数位置相同,偶数位置是原数组若干位置的和. 假如原数组A(a1, a2, a3, a4 ...),和其对应的树状数组C(c1, c2, ... 
- 2019全国大学生信息安全与对抗技术竞赛全国线下总决赛 Writeup
			0x00 Begin 关于 ISCC 2019 北理工总决赛,这一次比赛体验感总体差不多,最后我们战队荣获全国一等奖第一名,在这里非常感谢我的团队以及我的队友. 0x01 Reverse 下载题目:e ... 
- php的中文字符
			在使用substr截取字符窜的时候出现乱码的问题 一直任认为字符串是2个字节,直到多次才尝试才总算知道问题所在 php的utf-8字符是每个字符3个字节 而gbk字符是每个字节2个字符 单个字母和符号 ... 
- 初识Apache NiFi
			一. NiFi介绍 Apache NiFi支持功能强大且可扩展的数据路由,转换和系统中介逻辑的有向图. Apache NiFi的一些高级功能和目标包括: 基于Web的用户界面 设计,控制,反馈和监控之 ... 
- ArrayList源码分析--jdk1.8
			ArrayList概述 1. ArrayList是可以动态扩容和动态删除冗余容量的索引序列,基于数组实现的集合. 2. ArrayList支持随机访问.克隆.序列化,元素有序且可以重复. 3. ... 
- Java----面向对象(继承&多态)
			一.继承 什么是继承 ? 让类与类之间产生了子父类关系 ; 继承的好处是: 提高代码的复用性和维护性 java中继承的特点是: 只支持单继承.不支持多继承,但是可以多层继承; 四种权限修饰符是 : p ... 
- 安装MySQL5.7 安装环境:CentOS7 64位 MINI版,
			安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ... 
