React 组件的生命周期API和事件处理
一、简单记录React的组件的简洁的生命周期API:
A:实例化期:
一个实例第一次被创建时所调用的API与其它后续实例被创建时所调用的API略有不同。
实例第一次被创建时会调用getDefaultProps,而后续实例创建时不会调用这个方法。
实例被创建时,依次被调用的API有:
getDefaultProps:
实例第一次被创建时才调用,对于组件类来说,它只调用一次。
这个方法返回的对象可为实例设置默认的props值。
getInitialState:
对于每个实例来说,这个方法只调用一次。每次创建实例时执行一次。
在这里初始化每个实例的state,在这里可以访问到this.props。
componentWillMount:
在首次渲染之前被调用,在渲染之前更改组件state的最后机会。
render:
组件的唯一必需方法。创建虚拟DOM,表示组件输出。
只能通过this.props和this.state访问数据。
可以return null,return false,或return 任何React组件。
只能有一个顶级组件。
不能改变组件状态,或修改DOM的输出。
(注,render返回的结果说虚拟DOM,React随后会把它和真实DOM做对比,来判断是否有必要做出修改)
componentDidMount:
render成功调用并且真实DOM也已经被渲染后,这个方法会调用。
在这里可以通过this.getDOMNode()方法访问真实的DOM。
例如需要测量DOM元素的宽度和高度等属性,可以在这个方法里做。
(注,React跑在Server端时,componentDidMount不会被调用)
B:存在期:
随着应用状态的改变,以下API依次被调用:
componentWillReceiveProps
shouldComponentUpdate
componentWillUpdate
render
componentDidUpdate
C:销毁期:
组件被用完后,以下API被调用,给实例清理自身:
componentWillUnmount
注意反模式:
在getInitialState方法里,通过this.props来创建state的方法是一种反模式!
React专注于维护数据的单一来源,当组件的state值和它所基于的prop不同步时,是一种反模式!
反模式例子:
getDefaultProps: function() {
return { date: new Date() }
};
getInitialState: function() {
return {
day: this.props.date.getDay() // 不要在这里计算
}
};
render: function() {
return <div>Day is: {this.state.day}</div>;
};
正确的模式应该是在渲染时计算:(保证计算后的值不会与派生出它的props值不同步)
getDefaultProps: function() {
return { date: new Date() }
};
render: function() {
var day = this.props.date.getDay(); // 在渲染时做计算是正确的
return <div>Day is: {day}</div>;
};
注意,组件可以用this.props访问props,但不能修改自己的props!
关于state:
每个组件都有自己的state。state和props区别在于state只存在于组件内部。
state用来确定一个元素的视图状态。
state可以用setState或replaceState来修改。(不能用this.state来修改state)
只要setState或replaceState被调用,render就会被调用。如果render返回值有变化,DOM就会被更新。
二、React的事件处理:
事件文档:http://facebook.github.io/react/docs/events.html
绑定一个事件处理器:
React.DOM.button({className:"btn", onClick: this.handleSendClick}, "Send");
触控事件需要调用这个方法来手动启动:React.initializeTouchEvents(true);
更新组件状态会触发组件重绘。
setState会更新某一个state属性,而replaceState会替换掉整个state对象。
在绑定的事件处理器里做setState:
getInitialState: function() {
return { title: "Title 1.0" }
};
handlePageOnload: function(ev) {
this.setState({title: "Title 2.0"});
ev.preventDefault(); // 非必需,视情况而定
};
小结:更改state只能用setState或replaceState,因为它们可以通知React重绘DOM,即调用render方法。
补充:关于处理input的onChange事件:
handleComplete: function(event) {
this.callMethodOnProps("onCompleted", event.target.value);
};
render: function() {
return <textarea onBlur="{this.handleComplete}"></textarea>
};
注意,使用event.target.value获取input值是一种常规方法。
React 组件的生命周期API和事件处理的更多相关文章
- 2. React组件的生命周期
2. React组件的生命周期 使用React开发时候用到最多的就是React的组件了,通过继承React.Component,加入constructor构造函数,实现Render方法即可.这当中Re ...
- React 组件的生命周期方法
React 组件的生命周期方法 按渲染顺序: 1: componentWillMount() – 在渲染之前执行,在客户端和服务器端都会执行. 2: componentDidMount() – 仅在第 ...
- react第三单元(react组件的生命周期)
第三单元(react组件的生命周期) #课程目标 灵活掌握react组件的生命周期以及组件的活动过程. 能够灵活使用react的生命周期 #知识点 react的类组件的生命周期分为三个阶段 实例期 存 ...
- react 组件的生命周期 超简版
组件从被创建到被销毁的过程称为组件的 生命周期: 通常,组件的生命周期可以被分为三个阶段:挂载阶段.更新阶段.卸载阶段: 一.挂载阶段 这个阶段组件被创建,执行初始化,并被挂载到DOM中,完成组件的第 ...
- react 组件的生命周期
组件的生命周期 过程 装载(Mounting) :组件被插入到 DOM 中: 更新(Updating) :组件重新渲染以更新 DOM: 卸载(Unmounting) :组件从 DOM 中移除. 过程 ...
- React组件和生命周期简介
React 简介----React 是 Facebook 出品的一套颠覆式的前端开发类库.为什么说它是颠覆式的呢? 内存维护虚拟 DOM 对于传统的 DOM 维护,我们的步骤可能是:1.初始化 ...
- 理解React组件的生命周期
本文作者写作的时间较早,所以里面会出现很多的旧版ES5的时代的方法.不过,虽然如此并不影响读者理解组件的生命周期.反而是作者分为几种不同的触发机制来解释生命周期的各个方法,让读者更加容易理解涉及到的概 ...
- React: React组件的生命周期
一.简介 在前面的第二篇博文中对组件的生命周期虽然做了一个大略介绍,但总感觉说的过于简单,毕竟生命周期是React组件的核心部分.在我们熟练使用React挂载和合成组件来创建应用表现层的过程中,针对数 ...
- react组件的生命周期
写在前面: 阅读了多遍文章之后,自己总结了一个.一遍加强记忆,和日后回顾. 一.实例化(初始化) var Button = React.createClass({ getInitialState: f ...
随机推荐
- ArrayList 原理(2)
1. 概述 关于Java集合的小抄中是这样描述的: 以数组实现.节约空间,但数组有容量限制.超出限制时会增加50%容量,用System.arraycopy()复制到新的数组,因此最好能给出数组大小的预 ...
- 磁盘IO过高时的处理办法
针对系统中磁盘IO负载过高的指导性操作 主要命令:echo deadline > /sys/block/sda/queue/scheduler 注:以下的内容仅是提供参考,如果磁盘IO确实比较大 ...
- one by one 项目 part 3
mysql error:Table 'performance_schema.session_variables' doesn't exist 打开cmd 输入:mysql_upgrade -u roo ...
- 'Microsoft.VisualStudio.Editor.Implementation.EditorPackage' package did not load correctly
Visual Studio 2012 Ultimate Removing "C:\Users\UserName\AppData\Local\Microsoft\VisualStudio\11 ...
- 框架中spring有专门的类用于处理乱码
在三大框架spring中有专门的一个过滤器类用于处理乱码问题--->CharacterEncodingFilter 我们只需在web.xml中添加如下几行代码就可解决乱码问题 <filte ...
- php socket 函数
创建基于socket的应用程序,就需要详细了解socket的操作方法,这里列举PHP中一些重要的socket函数. 1. socket_create ( int $domain , int $ty ...
- Python 字符串操作,截取,长度
1.字符串操作: 字符串长度: s = "; slen = len(s); 字符串截取: print s[:-:-] #截取,逆序隔1个取一个字符 print s[:-:-] #截取,逆序隔 ...
- spring 在web容器启动时执行初始化方法
开发框架:spingMVC+myBatis 解决方案:给web容器添加一个Listener类,在容器启动的时候执行Listener的“初始化”方法,在这个初始化方法中执行查询数据库的所有操作,然后将数 ...
- struts2标签类别
要在jsp中使用Struts2的标志,先要指明标志的引入.通过jsp的代码的顶部加入以下的代码: <%@taglib prefix="s" uri="/struts ...
- 【原创】Junit4详解二:Junit4 Runner以及test case执行顺序和源代码理解
概要: 前一篇文章我们总体介绍了Junit4的用法以及一些简单的测试.之前我有个疑惑,Junit4怎么把一个test case跑起来的,在test case之前和之后我们能做些什么? Junit4执行 ...