React组件系统、props与状态(state)
多个组件合成一个组件:
var style = {
fontSize: 20,
color: '#ff0000'
};
var WebSite = React.createClass({
render: function () {
return (
<div style={style}>
<Name name={this.props.name} />
<Link link={this.props.link} />
</div>
);
}
});
var Name = React.createClass({
render: function () {
return (
<h1>{this.props.name}</h1>
);
}
});
var Link = React.createClass({
render: function () {
return (
<a href={this.props.link}>{this.props.link}</a>
)
}
});
React.render(<WebSite name="lqc" link="www.baidu.com" />, document.getElementById('example'));
State状态
getInitialState: function () { return {object: false;} }
this.setState({object: !this.state.object});
var LikeButton = React.createClass({
getInitialState: function () {
return {liked: false};
},
handleClick: function (event) {
this.setState({liked: !this.state.liked});
},
render: function () {
var text = this.state.liked ? '喜欢' : '不喜欢';
return (
<p onClick={this.handleClick}>
你<b>{text}</b>我。点我切换状态。
</p>
);
}
});
React.render(<LikeButton/>, document.getElementById('example'));
默认的props
var MyMessage = React.createClass({
getDefaultProps: function () {
return {
name: 'runoob'
}
},
render: function () {
return <h1>{this.props.name}</h1>
}
});
React.render(<MyMessage/>, document.getElementById('example'));
state和props混合使用
var Website = React.createClass({
getInitialState: function () {
return {
name: "百度",
link: 'http://www.baidu.com'
}
},
render: function () {
return (
<div>
<Name name={this.state.name} />
<Link link={this.state.link} />
</div>
);
}
});
// 构建下面两个组件的数据用props
var Name = React.createClass({
render: function () {
return (
<h1>{this.props.name}</h1>
)
}
});
var Link = React.createClass({
render: function () {
return (
<a href={this.props.link}>{this.props.link}</a>
)
}
});
React.render(<Website />, document.getElementById('example'));
Props验证使用propTypes
propTypes: {
title: React.PropTypes.string.isRequired
}
多个组件渲染可以写在同一页面:
var Website = React.createClass({
getInitialState: function () {
return {
name: "百度",
link: 'http://www.baidu.com'
}
},
render: function () {
return (
<div>
<Name name={this.state.name} />
<Link link={this.state.link} />
</div>
);
}
});
// 构建下面两个组件的数据用props
var Name = React.createClass({
render: function () {
return (
<h1>{this.props.name}</h1>
)
}
});
var Link = React.createClass({
render: function () {
return (
<a href={this.props.link}>{this.props.link}</a>
)
}
});
React.render(<Website />, document.getElementById('example'));
// Props验证使用propTypes
var title= 'React';
var MyTitle = React.createClass({
propTypes: {
title: React.PropTypes.string.isRequired
},
render: function () {
return (
<h1>{this.props.title}</h1>
)
}
});
React.render(<MyTitle title={title} />, document.getElementById('example2'));
下一节:
React组件的生命周期
React组件系统、props与状态(state)的更多相关文章
- React创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值
创建组件的方法,组件的props属性.state属性的用法和特点,父子组件传值,兄弟组件传值 1.react组件 1.1.创建组件的方法 1.1.1.函数组件 定义一个组件最简单的方式是使用JavaS ...
- 组件的props属性和state状态
props属性: 我使用代码来说明React中props属性: // Profile.jsx import React from 'react' ; export default Class Prof ...
- 创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值
1.创建组件的方法 函数组件 class组件 1.1 函数组 无状态函数式组件形式上表现为一个只带有一个 `render()` 方法的组件类,通过函数形式或者 `ES6` 箭头 `functi ...
- React Native中组件的props和state
一.组件的属性(props)和状态(state) 1.属性(props) 它是组件的不可变属性(组件自己不可以自己修改props). 组件自身定义了一组props作为对外提供的接口,展示一个组件时只需 ...
- 【react】利用prop-types第三方库对组件的props中的变量进行类型检测
1.引言--JavaScript就是一个熊孩子 1.1对于JSer们来说,js是自由的,但同时又有许多让人烦恼的地方.javascript很多时候就是这么一个熊孩子,他很多时候并不会像C和java ...
- React组件开发
目录: 属性:props 内联样式 状态记忆 : state 生命周期 访问DOM 表单输入 承接快速入门篇:http://www.cnblogs.com/jasonnode/p/4444504.ht ...
- 深入React组件生命周期
上篇博文使用React开发的一些注意要点对React开发的一些重点进行了简单的罗列总结,虽然也提到了React生命周期,但只略微小结,在此单独写篇React生命周期的总结. 在组件的整个生命周期中,随 ...
- React组件和生命周期简介
React 简介----React 是 Facebook 出品的一套颠覆式的前端开发类库.为什么说它是颠覆式的呢? 内存维护虚拟 DOM 对于传统的 DOM 维护,我们的步骤可能是:1.初始化 ...
- React组件性能调优
React是一个专注于UI层的框架,它使用虚拟DOM技术,以保证它UI的高速渲染:使用单向数据流,因此它数据绑定更加简单:那么它内部是如何保持简单高效的UI渲染呢?这种渲染机制有可能存在什么性能问题呢 ...
随机推荐
- AngularJS学习--- AngularJS中XHR(AJAX)和依赖注入(DI) step5
前言:本文接前一篇文章,主要介绍什么是XHR,AJAX,DI,angularjs中如何使用XHR和DI. 1.切换工具目录 git checkout -f step- #切换分支 npm start ...
- Oracle Database常用补丁集Patch号及各版本PSU
Oracle Database常用补丁集Patch号及各版本PSU------------------------------------------------------------------- ...
- oracle 驱动安装备忘
ubuntu 从oracle官网下载两个必须的rpm包(这里选择的是version12.1.0.2.0, 64位操作系统) oracle-instantclient12.1-basic-12.1.0. ...
- 自已实现的async 只实现了一部分功能
不得不说,人和人的技术确实有差距,同样的功能,其他人就是有办写写的更优雅性能更好 不论是C还是js 自已有功能但看着也比人家的丑好多. //最终效果 同async //目前实现了个人最常用的 seri ...
- ThinkPHP中add()方法的返回值
在处理业务数据的时候,有时会遇到需要取得刚insert的数据的主键id值. 以前的做法都是先插入数据后,再通过查询获得id值. 后来在学习ThinkPHP开发的时候才知道,add()方法在写入成功后得 ...
- 4.“写程序” 这个活动大多数情况下是个人行为。 我们听说的优秀程序员似乎都是单打独斗地完成任务。同学们在大学里也认识一些参加ACM 比赛的编程牛人, 他们写的ACM 比赛的程序是软件么? “写程序” 和 ”做软件“ 有区别么? 请采访这些学生。
ACM的题库的编程都只能算做程序,不能算软件.写程序和做软件区别还是很大的.程序是为实现特定目标或解决特定问题而用计算机语言编写的命令序列的集合.为实现预期目的而进行操作的一系列语句和指令.而软件是程 ...
- 准备找工作第三天——java基础_由有道云笔记倒入
循环:跳出多重循环:通过设置标号: 1 ok: 2 for(int i=0;i<10;i++) 3 { 4 for(int j=0;j<10;j++) 5 { ...
- (算是dp吧) 小茗的魔法阵 (fzu 2225)
http://acm.fzu.edu.cn/problem.php?pid=2225 Problem Description 在打败了易基•普罗布朗.诺姆•普罗布朗之后,小茗同学开始挑战哈德•普罗 ...
- alert()、confirm()和prompt()的区别
1.警告消息框alertalert 方法有一个参数,即希望对用户显示的文本字符串.该字符串不是 HTML 格式.该消息框提供了一个“确定”按钮让用户关闭该消息框,并且该消息框是模式对话框,也就是说,用 ...
- 取td里面的内容
var rowLength = document.getElementById("table名字").rows.length; for(var i=0;i<rowLeng ...