react学习笔记-05 lifecycle
根据React官网,react有三个生命状态:装载(Mounting),更新(updating),卸载()
一:装载
装载:componentWillMount/componentDidMount(组件即将被装载、组件已经被装载)
export default class blog extends React.Component{ constructor(props){ super(props); this.state = {count:0}; }; componentWillMount(){ console.log("will mount"); }; componentDidMount(){ console.log("did mount");
console.log(ReactDom.findDOMNode(this)); }; render(){
console.log("render"); return ( <div>hello world! {this.state.count}</div> ); } }
输出结果:
可以看出,在componentWillMount里面进行setState,组件不会重新渲染.如果在componentDidMount里面setState,组件会重新渲染。
在render结束之后,就可以获得DOM 节点了。
在componentDidMount通常做一些ajax或者settimeout/setInterval操作,再更新DOM进行update操作
二:卸载
componentWillunMount:取消事件监听,清除定时器
export default class blog extends React.Component{ constructor(props){ super(props); this.state = {count:0}; }; componentWillMount(){ console.log("will mount"); this.setState({ count:3 }); }; componentDidMount(){ console.log("did mount"); console.log(ReactDom.findDOMNode(this)); }; componentWillUnmount(){ console.log("you want kill me?"); }; killMyself(){ ReactDom.unmountComponentAtNode(document.getElementById('blog')); console.log("yes, I want to kill you"); }; render(){ console.log("render"); return ( <div>hello world! {this.state.count} <button onClick = {this.killMyself} value="kill"></button> </div> ); } }
如果在componentWillMount里面使用setInterval:
componentWillMount(){ console.log("will mount"); var self = this; this.timer = setInterval(function(){ self.setState({count:self.state.count+1}); },1000); };
点击清空按钮后会出现下面warning:
该warning的出现是因为DOM被清除了,但是计时器还在。所以这个时候可以在componentWillUnmount里面清空setInterval
componentWillUnmount(){ console.log("you want kill me?"); clearInterval(this.timer); };
三:更新
第一次创建组件的时候,不会调用update相关的方法。
shouldComponentUpdate返回true时,其他的update方法才会被触发。
shouldComponentUpdate(nextProp,nextState){ //判断是否需要重新渲染 console.log("shouldComponentUpdate"); if(nextState >2){ return false; } return true; }; componentWillUpdate(nextProps,nextState){ //做一些数据的处理 console.log("componentWillUpdate"); }; componentDidUpdate(){ //可以获取更新后的DOM结构 console.log("update success"); }; doUpdate(){ this.setState({count:this.state.count+1}); }; render(){ console.log("render"); return ( <div>hello world! {this.state.count} <button onClick = {this.doUpdate.bind(this)}>update</button> </div> ); }
还有一个重要的update方法:
componentWillReceivePops
用props更新子组件的state,判断子组件是否更新
var SubMessage = React.createClass({ componentWillReceiveProps (nextProps){ console.log("子组件将要获得props"); }, shouldComponentUpdate (nextProps,nextState){ if(nextProps.count >4){ return false; } return true; }, render(){ return (<h3>{this.props.count}</h3>); } }); export default class blog extends React.Component{ constructor(props){ super(props); this.state = {count:0}; }; //更新周期 shouldComponentUpdate (nextProp,nextState){ //判断是否需要重新渲染 console.log("shouldComponentUpdate"); if(nextState.count >8){ return false; } return true; }; componentWillUpdate(nextProps,nextState){ //做一些数据的处理 console.log("componentWillUpdate"); }; componentDidUpdate(){ //可以获取更新后的DOM结构 console.log("update success"); }; doUpdate(){ this.setState({count:this.state.count+1}); }; render(){ console.log("render"); return ( <div>hello world! {this.state.count} <button onClick = {this.doUpdate.bind(this)}>update</button> <SubMessage count={this.state.count}></SubMessage> </div> ); } }
react学习笔记-05 lifecycle的更多相关文章
- React学习笔记--程序调试
React学习笔记 二 程序调试 前面我们搭建好了React的基本开发环境,可以编写基本的React js程序了.但完成的开发环境肯定包含调试器,怎么调试用React编写的JS程序呢?有浏览器,比 ...
- react学习笔记1--基础知识
什么是react A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES[React是一个用于构建用户界面的JavaScript库.] React之所以快, ...
- React学习笔记(一)- 入门笔记
React入门指南 作者:狐狸家的鱼 本文链接:React学习笔记 GitHub:sueRimn 1.组件内部状态state的修改 修改组件的每个状态,组件的render()方法都会再次运行.这样就可 ...
- 机器学习实战(Machine Learning in Action)学习笔记————05.Logistic回归
机器学习实战(Machine Learning in Action)学习笔记————05.Logistic回归 关键字:Logistic回归.python.源码解析.测试作者:米仓山下时间:2018- ...
- React学习笔记(七)条件渲染
React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...
- React学习笔记(六)事件处理
React学习笔记(六) 五.事件处理 React事件绑定属性的命名采用驼峰写法,不同于传统DOM全部小写. 如果采用JSX的语法,事件函数需要用大括号{}包裹函数名,不同于传统DOM字符串小括号的方 ...
- React学习笔记(五)State&声明周期
React学习笔记(五) 四.State&声明周期 可以为组件添加"状态(state)".状态与属性相似,但是状态是私有的,完全受控于当前组件. 局部状态就是只能用于类(定 ...
- React学习笔记 - 组件&Props
React Learn Note 4 React学习笔记(四) 标签(空格分隔): React JavaScript 三.组件&Props 组件可以将UI切分成一些独立的.可复用的部件,这样你 ...
- React学习笔记 - 元素渲染
React Learn Note 3 React学习笔记(三) 标签(空格分隔): React JavaScript 二.元素渲染 元素是构成react应用的最小单位. 元素是普通的对象. 元素是构成 ...
随机推荐
- iOS7 初体验
iOS7 初体验 近日来由于iOS7的发布,引来业界的各种吐槽. 为了体验一把,我已经把iPhone5刷成了iOS7,也下载Xcode5-DP并进行了测试.我想说的是iOS7与Xcode5-DP中新增 ...
- 当ArcGIS10.2遇到Teradata
随着计算机技术的不断发展,GIS技术也紧跟IT技术的热潮,从三维技术.到移动技术,从大数据技术到云计算技术,只要IT有的新技术,Esri ...
- 【C++自我精讲】基础系列四 static
[C++自我精讲]基础系列四 static 0 前言 变量的存储类型:存储类型按变量的生存期划分,分动态存储方式和静态存储方式. 1)动态存储方式的变量,生存期为变量所在的作用域.即程序运行到此变量时 ...
- IPC之消息队列详解与使用
一. 概念 消息队列就是一个消息的链表.对消息队列有写权限的进程可以向其中按照一定的规则添加新消息:对消息队列有读权限的进程可以从消息队列中读出消息.消息队列是随内核持续的.下面介绍三个概念: ...
- java基础练习 1
import java.util.Scanner; public class First { /* * 编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函 ...
- Spring IOC的理解
学习过Spring框架的人一定都会听过Spring的IoC(控制反转) .DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC .DI这两个概念是模糊不清的,是很难理 ...
- 仿qq的侧拉菜单效果
自定义控件 import android.animation.ArgbEvaluator; import android.animation.FloatEvaluator; import androi ...
- C#中对属性和字段的理解
字段 C#中很少提到全局变量的概念, 引入了字段一词来代替全局变量, 但也并不是这样简单的, 字段会比全局变量的使用更难理解, 使用上会简单, 初学者当做成员变量或者全局变量不会有什么影响, 随着使用 ...
- .net: 不能忽视的break——寻找VS2010和VS2012编译器的一个小区别
文中的问题来自于实际开发,但是实际开发中的代码逻辑比较复杂,因此下面的代码去掉了所有逻辑,只保留能体现问题的代码,类和都只为了说明问题,并不具有实际意义.下面首先看看下面的代码和现象. 1. 问题再现 ...
- android 界面布局
一.LinearLayout LinearLayout 又称作线性布局,是一种非常常用的布局,它所包含的控件在线性方向上依次排列. android:orientation="horizont ...