componentWillMount VS componentDidMount
前言
这与React组件的生命周期有关,组件挂载时有关的生命周期有以下几个:
constructor(){}
componentWillMount(){}
render(){}
componentDidMount(){}
上面这些方法的调用是有次序的,由上而下,也就是当说如果你要获取外部数据并加载到组件上,只能在组件"已经"挂载到真实的网页上才能作这事情,其它情况你是加载不到组件的。
componentWillMount VS componentDidMount
constructor
被调用是在组件准备要挂载的最一开始,所以此时组件尚未挂载到网页上。
componentWillMount方法
- 将要装载,调用在constructor之后,在render之前,
- 每一个组件render之前立即调用
- 可以在服务端被调用,也可以在浏览器端被调用
 如果你需要在服务器端渲染应用程序,componentWillMount将被调用两次。一次是在server端,一次在客户端,但这并不是你想要的结果而将数据加载逻辑放在componentDidMount将确保数据只从客户端获取
- 在这方法里的代码调用setState方法不会触发重渲染,所以它一般不会用来作加载数据之用,它也很少被使用到。
extend component的方式里的constructor函数和componentWillMount是通用的作用,所以你在构造函数里初始化了组件的状态就不必在WillMount做重复的事情了
componentDidMount方法
- 装载完成,在render之后调用
- render之后并不会立即调用,而是所有的子组件都render完之后才可以调用
- 只能在浏览器端被调用,在服务器端使用react的时候不会被调用
- 在这方法中调用setState方法,会触发重渲染,所以,官方设计这个方法就是用来加载外部数据用的,或处理其他的副作用代码。
- 是在组件已经完全挂载到网页上才会调用被执行,所以可以保证数据的加载。
componentWillMount VS componentDidMount的更多相关文章
- componentWillMount和componentDidMount的区别
		1.componentWillMount 将要装载,在render之前调用: componentDidMount,(装载完成),在render之后调用 2.componentWillMount 每 ... 
- react手记(componentWillMount,componentDidMount等)
		生命周期componentWillMount 组件出现前 就是dom还没有渲染到html文档里面componentDidMount 组件渲染完成 已经出现在dom文档里可以再各个周期实现特定的操作 生 ... 
- 移动web端的react.js组件化方案
		背景: 随着互联网世界的兴起,web前端开发的方式越来越多,出现了很多种场景开发的前端架构体系,也对前端的要求日益增高,早已经不是靠一个JQuery.js来做前端页面的时代了,而今移动端变化最大,近 ... 
- React生命周期
		在react生命周期中,分2段执行,一个挂载的生命周期,一个是组件发生了数据变动,或者事件触发而引发的更新生命周期. 注:react生命周期很重要,对于很多组件场景的应用发挥重要作用,而且不熟悉生命周 ... 
- React源码剖析系列 - 生命周期的管理艺术
		目前,前端领域中 React 势头正盛,很少能够深入剖析内部实现机制和原理.本系列文章希望通过剖析 React 源码,理解其内部的实现原理,知其然更要知其所以然. 对于 React,其组件生命周期(C ... 
- react9 生命周期
		<body><!-- React 真实 DOM 将会插入到这里 --><div id="example"></div> <!- ... 
- [React] 多组件生命周期转换关系
		前段时间一直在基于React做开发,最近得空做一些总结,防止以后踩坑. 言归正传,React生命周期是React组件运行的基础,本文主要是归纳多组件平行.嵌套时,生命周期转换关系. 生命周期 Reac ... 
- react学习小结(生命周期- 实例化时期 - 存在期- 销毁时期)
		react学习小结 本文是我学习react的阶段性小结,如果看官你是react资深玩家,那么还请就此打住移步他处,如果你想给一些建议和指导,那么还请轻拍~ 目前团队内对react的使用非常普遍,之 ... 
- 野心勃勃的React组件生命周期
		当你还在写着Angular指令,过滤器,注入,服务,提供者,视图模版的时候,是不是觉得很烦,好在这个时候,React已经神一样的出现在历史舞台. React组件 React实现了UI=Fn(St ... 
随机推荐
- linux 打包 | autoconf 使用方法
			面试题 嵌入式 0x10道题目 宏定义 #define 宏体 宏体 (大写) #define SECOND_OF_YEAR (365*24*3600)UL 可移植性 数据声明 一个存有10个指针的数组 ... 
- [LINQ2Dapper]最完整Dapper To Linq框架(七)---仓储模式
			目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ... 
- 痞子衡嵌入式:串行EEPROM接口事实标准及SPI EEPROM简介
			大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是EEPROM接口标准及SPI EEPROM. 痞子衡之前写过一篇文章 <SLC Parallel NOR简介>,介绍过并行N ... 
- ActiveMQ消息队列从入门到实践(1)—JMS的概念和JMS消息模型
			1. 面向消息的中间件 1.1 什么是MOM 面向消息的中间件,Message Oriented Middleware,简称MOM,中文简称消息中间件,利用高效可靠的消息传递机制进行平台无关的数据交流 ... 
- Jetpack Compse 实战 —— 全新的开发体验
			公众号回复 Compose 获取安装包 项目地址: Wanandroid-Compose 经过前段时间的 Android Dev Summit ,相信你已经大概了解了 Jetpack Compose ... 
- 微服务SpringCloud之GateWay熔断、限流、重试
			纯洁的微笑的Spring Cloud系列博客终于学完了,也对Spring Cloud有了初步的了解. 修改请求路径的过滤器 StripPrefix Filter 是一个请求路径截取的功能,我们可以利用 ... 
- 深入理解 DNS
			深入理解 DNS 简介 DNS(Domain Name System)域名系统,它是一个将域名和 IP 地址相互映射的一个分布式数据库,把容易记忆的主机名转换成主机 IP 地址. DNS使用 TCP ... 
- [RAM] FPGA的学习笔记——RAM
			1.RAM——随机存取存储器, 分为SRAM和DRAM. SRAM:存和取得速度快,操作简单.然而,成本高,很难做到很大.FPGA的片内存储器,就是一种SRAM,用来存放程序,以及程序执行过程中,产生 ... 
- ubuntu 18 怎样对Windows进行远程桌面控制
			ubuntu 18 怎样对Windows进行远程桌面控制: 1. 先安装一个redesktop 工具(sudo apt-get install redesktop) 2. 在通过 redesktop ... 
- MAC系统下,Jmeter5.1.1 无法录制问题
			问题一: 点击[start]先出现一个检查证书信息的弹窗,确保删除旧的安装新的,并且需要信任证书 (一般证书只需要信任一下即可,每次启动都会有这个弹窗提醒) 问题二: MAC OS系统使用Jmeter ... 
