React学习笔记(三) 组件传值
组件嵌套后,父组件怎么向子组件发送数据呢?
答案是: this.props
<script type="text/babel">
var MyFirst = React.createClass({
getInitialState : function(){
return {
myMessage: ['我是父组件data1','我是父组件data2','我是父组件data3',]
}
},
render : function(){
return (
<div>
<h3>父组件</h3>
<MySecond name={this.state.myMessage} />
</div>
)
}
});
var MySecond = React.createClass({
render : function(){
var msg = [];
var message = this.props.name;
message.forEach(function(value,key){
msg.push(
<p key={key}>我的消息{key}:{value}</p>
)
})
return (
<div>
{msg}
</div>
)
}
})
var haFirst = ReactDOM.render(
<MyFirst />,
document.getElementById("test"),
function(){
console.log('编译完成!');
}
)
</script>
有的时候父组件传过来的数据类型跟子组件需要的类型不一样,那该怎么办呢?
PropTypes属性,就是用来验证组件实例的属性是否符合要求
var MyTitle = React.createClass({
propTypes: {
title: React.PropTypes.string.isRequired,
},
render: function() {
return <h1> {this.props.title} </h1>;
}
});
PropTypes的类型有很多:
React.PropTypes.array React.PropTypes.bool React.PropTypes.func React.PropTypes.number React.PropTypes.object React.PropTypes.string React.PropTypes.node React.PropTypes.element
若属性不符合要求此外,我们可以用getDefaultProps 方法可以用来设置组件属性的默认值
<script type="text/babel">
var MyFirst = React.createClass({
getInitialState : function(){
return {
myMessage: ['我是父组件data1','我是父组件data2','我是父组件data3',]
}
},
render : function(){
return (
<div>
<h3>父组件</h3>
<MySecond />
</div>
)
}
});
var MySecond = React.createClass({
getDefaultProps : function(){ //设置默认值
return {
name : [,,]
}
},
PropTypes : { //定义变量的类型:数组且必须
name : React.PropTypes.array.isRequired
},
render : function(){
var msg = [];
var message = this.props.name;
message.forEach(function(value,key){
msg.push(
<p key={key}>我的消息{key}:{value}</p>
)
})
return (
<div>
{msg}
</div>
)
}
})
var haFirst = ReactDOM.render(
<MyFirst />,
document.getElementById("test"),
function(){
console.log('编译完成!');
}
)
</script>
如上:父组件如果没有给子组件传值,或者传值的类型不对,子组件将自动调用默认值1,2,3
PS:当你在写react的时候报了类似于这样子的错:Each child in an array or iterator should have a unique “key” prop.
解决办法只要在循环的每个子项添加一个key就行了,代码如下:
var names = ['Alice', 'Emily', 'Kate'];
ReactDOM.render(
<div>
{
names.map(function (name, key) {
return <div key={key}>Hello, {name}!</div>
})
}
</div>,
document.getElementById('example')
);
React学习笔记(三) 组件传值的更多相关文章
- angular学习笔记 父子组件传值
一.如何将父组件的值传到子组件? 在子组件里面引入Input,然后用@Input 变量1 接收 接着在父组件中的,子组件标签上添加[msg]="msg",中括号里的名字要与子组件中 ...
- 【React】react学习笔记03-React组件对象的三大属性-state
今天晚上学习了React中state的使用,特做此记录,对于学习的方式,博主仍然推荐直接复制完整代码,对着注释观察现象!: 上文中,我列举了两种React自定义组件的声明,这里我拿方式二进行举例: / ...
- React学习笔记(二) 组件状态
组件的状态(this.state): 组件免不了要与用户互动,React 的一大创新,就是将组件看成是一个状态机,一开始有一个初始状态,然后用户互动,导致状态变化,从而触发重新渲染 UI getIni ...
- React学习笔记 - 组件&Props
React Learn Note 4 React学习笔记(四) 标签(空格分隔): React JavaScript 三.组件&Props 组件可以将UI切分成一些独立的.可复用的部件,这样你 ...
- 【React】react学习笔记02-面向组件编程
react学习笔记02-面向组件编程 面向组件编程,直白来说,就是定义组件,使用组件. 以下内容则简单介绍下组建的声明与使用,直接复制demo观测结果即可. 步骤: 1.定义组件 a.轻量组件-函 ...
- react学习笔记1--基础知识
什么是react A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES[React是一个用于构建用户界面的JavaScript库.] React之所以快, ...
- React学习笔记 - 元素渲染
React Learn Note 3 React学习笔记(三) 标签(空格分隔): React JavaScript 二.元素渲染 元素是构成react应用的最小单位. 元素是普通的对象. 元素是构成 ...
- React学习笔记 - JSX简介
React Learn Note 2 React学习笔记(二) 标签(空格分隔): React JavaScript 一.JSX简介 像const element = <h1>Hello ...
- React学习笔记 - Hello World
React Learn Note 1 React学习笔记(一) 标签(空格分隔): React JavaScript 前.Hello World 1. 创建单页面应用 使用Create React A ...
随机推荐
- LR测试工具性能指标详解
这篇文章将对LoadRunner测试工具的性能指标从以下三点进行详解. 第一点.Web资源分析是从服务器入手对Web服务器的性能分析. 1.Hits per Second "每秒点击次数&q ...
- Linux内核学习笔记2——Linux内核源码结构
一 内核组成部分 内核是一个操作系统的核心,主要由五个部分组成:进程调度,内存管理,虚拟文件系统,网络结构,进程间通信. 1.进程调度(SCHED) 控制进程对CPU的访问.当需要选择下一个进程运行时 ...
- Tsinsen A1504. Book(王迪) 数论,贪心
题目:http://www.tsinsen.com/A1504 A1504. Book(王迪) 时间限制:1.0s 内存限制:256.0MB Special Judge 总提交次数:359 ...
- yum puppet 并整合控制台
上篇说了下在ubuntu12.04上安装puppet,安装的版本为puppet2.7.11版本,今天尝试了下在CentOS6.4系统上安装puppet 3.1.1版本,本文参考chenshake的文章 ...
- 4 weekend110的textinputformat对切片规划的源码分析 + 倒排索引的mr实现 + 多个job在同一个main方法中提交
好的,现在,来weekend110的textinputformat对切片规划的源码分析, Inputformat默认是textinputformat,一通百通. 这就是今天,weekend110的te ...
- 常用js效果:选项卡切换
js选项卡,很多网站都会用到,我这里用jquery给整了一个简单但是却很实用的js选项卡,废话不多说,直接上代码: <style> .txtadsblk01{ width:200px;} ...
- Microsoft.Jet.Oledb.4.0 提供者並未登錄於本機電腦上
最近把一些 .NET2.0 的專案從 x86 的 Server 搬到 x64 的 Server 上,一直都相安無事,直到今天才發現使用 Oledb 讀取 Excel 的時候會跳出「'Microsoft ...
- ab apache Benchmarking中链接的写法 记得加上/
C:\wamp\bin\apache\Apache2.2.21\bin>ab.exe -n5 -c5 http://www.baidu.com ab.exe: invalid URL Usage ...
- 在CentOS搭建Git服务器 转
在CentOS搭建Git服务器 来自 :http://www.jianshu.com/p/69ea5ded3ede 前言 我们可以GitHub发布一些开源代码的公共仓库,但对于私密仓库就需要收费了.公 ...
- mysql2redis
mysql2redis这个项目主要解决mysql数据跟redis数据同步的问题 目前在测试环境研究这方面的应用,以下是git上面的介绍 git入口 git安装入口 Dependencies pl ...