React(三)组件的生命周期
Component Specs and LifeCycle
<div id="app"></div>
<script src="bower_components/react/react.min.js"></script>
<script src="bower_components/react/react-dom.min.js"></script>
<script src="lib/babel-core/browser.min.js"></script>
<script type="text/babel">
var MessageBox = React.createClass({
getInitialState: function () {
return {
count: 0
}
},
componentWillMount: function () {
console.log('componentWillMount');
var self = this;
this.timer = setInterval(function () {
self.setState({
count: self.state.count + 1
});
}, 1000);
},
componentDidMount: function () {
console.log('componentDidMount');
console.log(this);
},
componentWillUnmount: function () {
console.log('卸载掉组件');
clearInterval(this.timer);
},
render: function () {
return (
<div>
<h1>{this.state.count}</h1>
</div>
);
}
});
var messagebox = ReactDOM.render(
<MessageBox/>,
document.getElementById('app')
);
</script>
<div id="app"></div>
<script src="bower_components/react/react.min.js"></script>
<script src="bower_components/react/react-dom.min.js"></script>
<script src="lib/babel-core/browser.min.js"></script>
<script type="text/babel">
var MessageBox = React.createClass({
getInitialState: function () {
return {
count: 0
}
},
getDefaultProps: function () {
},
/*componentWillMount: function () {
},
componentDidMount: function () {
},
componentWillUnmount: function () {
},
*/
shouldComponentUpdate: function (nextProp, nextState) {
console.log('shouldComponentUpdate');
if(nextState.count > 3) return false;
return true; // 必须返回一个true或者false
},
componentWillUpdate: function (nextProp, nextState) {
console.log('componentWillUpdate');
},
componentDidUpdate: function () {
console.log('成功更新啦');
},
doUpdate: function () {
this.setState({
count: this.state.count + 1
});
},
render: function () {
return (
<div>
<h1>{this.state.count}</h1>
<button onClick={this.doUpdate}>手动更新一下组件(包括子组件)</button>
<SubMessage message={this.state.count} />
</div>
);
}
});
var SubMessage = React.createClass({
componentWillReceiveProps: function (nextProp) {
console.log('子组件将要获得prop');
},
shouldComponentUpdate: function (nextProp, nextState) {
if(nextProp.message > 2) return false;
return true;
},
render: function () {
return (
<div>
<h3>{this.props.message}</h3>
</div>
);
}
});
var messagebox = ReactDOM.render(
<MessageBox/>,
document.getElementById('app')
);
</script>
React(三)组件的生命周期的更多相关文章
- reactjs入门到实战(七)---- React的组件的生命周期
React的组件的生命周期有三个状态分别是:挂载(生产组件示例化.准备挂载到页面.挂载到页面).更新(更新值.更新DOM).和卸载(卸载后). >>>其他 getInitia ...
- react native组件的生命周期
react native组件的生命周期 一.当页面第一次加载时,会依次调用: constructor() componentWillMount(): 这个函数调用时机是在组件创建,并初始化了状态之后, ...
- Android React Native组件的生命周期及回调函数
熟悉android的童鞋应该都清楚,android是有生命周期的,其很多组件也是有生命周期.今天小编和大家分享的React Native组件的生命周期,还不了解的童鞋,赶紧来围观吧 在android开 ...
- 【RN - 基础】之React Native组件的生命周期
下图描述了React Native中组件的生命周期: 从上图中可以看到,React Native组件的生命周期可以分为初始化阶段.存在阶段和销毁阶段. 实例化阶段 实例化阶段是React Native ...
- React Native组件、生命周期及属性传值props详解
创建组件的三种方式 第一种:通过ES6的方式创建 /** * 方式一 :ES6 */ export default class HelloComponent extends Component { r ...
- React:组件的生命周期
在组件的整个生命周期中,随着该组件的props或者state发生改变,其DOM表现也会有相应的变化.一个组件就是一个状态机,对于特定地输入,它总返回一致的输出. 一个React组件的生命周期分为三个部 ...
- react教程 — 组件的生命周期 和 执行顺序
一.组件执行的生命周期: 参考 https://www.cnblogs.com/soyxiaobi/p/9559117.html 或 https://www.c ...
- React Native——组件的生命周期
组件生命周期 上流程图描述了组件从创建.运行到销毁的整个过程,可以看到如果一个组件在被创建,从开始一直到运行会依次调用getDefaultProps到render这五个函数:在运行过程中,如果有属性和 ...
- React入门--------组件的生命周期
Mounting/组件挂载相关: componentWillMount componentDidMount Updating/组件更新相关: componentWillReceiveProps sho ...
随机推荐
- 通过navigationController跳转界面时隐藏navigationBar上的元素
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...
- low到一定程度了
- Pyhton开源框架(加强版)
info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ...
- iOS开发零基础--Swift教程 字符串的利用
字符串的介绍 字符串在任何的开发中使用都是非常频繁的 OC和Swift中字符串的区别 在OC中字符串类型时NSString,在Swift中字符串类型是String OC中字符串@"" ...
- android开发学习之Level List篇
Level List google 说明:A Drawable that manages a number of alternate Drawables, each assigned a maximu ...
- React 随笔二
这周做的demo3和demo4.5 随记的小点. 1.js错误提示: Warning: Each child in an array or iterator should have a unique ...
- LINUX下常用SHELL指令
Linux Shell常用shell命令 一.文件.目录操作命令 1.ls命令 功能:显示文件和目录的信息 ls 以默认方式显示当前目录文件列表 ls -a 显示所有文件包括隐藏文件 ls -l 显示 ...
- linux-dns服务器搭建
1.先查看系统是否安装了bind rpm -qa|grep bind 2.如果没有安装则
- Oracle Profile 使用
一.目的: Oracle系统中的profile可以用来对用户所能使用的数据库资源进行限制,使用Create Profile命令创建一个Profile,用它来实现对数据库资源的限制使用,如果把该prof ...
- Xamarin.Android之MvvmCross
欢迎大家加入以下开源社区 Xamarin-Cn:https://github.com/Xamarin-Cn Mvvmcross-Cn:https://github.com/Mvvmcross-Cn ...