React学习小结(三)
一、React数据的传输
1、属性和状态是react中数据传递的载体
2、属性是声明以后不允许被修改的东西
3、属性只能在组件初始化的时候声明并传入组件内部,并且在组件内部通过this.props获取
4、组件内部可以通过getDefaultProps声明默认属性
下面来说一下属性传值的两种方式:1.key-value形式 2.展开式
首先来看一下第一种传值方式:
var Demo = React.createClass({
render:function(){
var sty={width:'500px',height:'200px',border:'1px solid red',margin:'0 auto'}
console.log(this.props)
return(
<div>
<h1>属性字符串:{this.props.name}</h1>
<h1>属性数组:{this.props.aa[2]}</h1>
<div style={sty}>{this.props.bb.age}<br/>{this.props.bb.age1}<br/>{this.props.bb.age2}</div>
</div>
)
}
})
var str="hello react";
var arr=['你好',2222,'hi'];
var obj={
age:'白雪公主',
age1:'七个小矮人',
age2:'毒苹果'
}
ReactDOM.render(<Demo name={str} aa={arr} bb={obj} cc={arrx} dd={arry}/>,document.getElementById("out"))
/*
1/key-value形式 正常数据传值,组件内部this。props获取(对象)
2/{...}展开式传值 传输数据对对象形式,内部获取直接获取该对象的key名
*/
然后我们再看一下第二种展开式的传值方式:
注:展开式传值不能传字符串!非对象的形式不要用展开式传值!
ReactDOM.render(<Demo1 {...obj}/>,document.getElementById('out'))
组合数据:
var Demo = React.createClass({
render:function(){
var sty={width:'500px',height:'200px',border:'1px solid red',margin:'0 auto'}
console.log(this.props)
return(
<div>
<h2>组合数据数组:{this.props.cc[1][0]}{this.props.cc[2].age}</h2>
<h2>组合数据对象:{this.props.dd.name2.age} <br/> {this.props.dd.name3[0]}</h2>
</div>
)
}
})
var arrx=[
'hello react',
['你好',2222,'hi'],
{
age:'白雪公主',
age1:'七个小矮人',
age2:'毒苹果'
}
]
var arry = {
name:'hello react',
name2:{
age:'白雪公主',
age1:'七个小矮人',
age2:'毒苹果'
},
name3:['你好',2222,'hi']
}
ReactDOM.render(<Demo name={str} aa={arr} bb={obj} cc={arrx} dd={arry}/>,document.getElementById("out"))
通过演示这两种传值方式我们可以看到,属性需要在ReactDOM.render 组件名后面加如此多自定义属性这样书写代码是不优雅的,看着很不舒服,那么如何优雅呢?上面我们也提到可以通过React生命周期的一个函数来声明组件内的默认属性,来看一下是不是优雅多了:
var Demo = React.createClass({
getDefaultProps:function(){
return{
res:'hi react',
res1:[1,2,3],
res2:{name:'小明'}
}
},
render:function(){
console.log(this.props)
return(
<div>
<h1>组件内部私有属性:{this.props.res}{this.props.res1[1]}{this.props.res2.name}</h1>
</div>
)
}
})
ReactDOM.render(<Demo/>,document.getElementById("out"))
状态传值
var Demo = React.createClass({
getDefaultProps:function(){
return{
res:'hi react'
}
},
getInitialState:function(){
return{
res:'hello state'
}
},
tap:function(){
this.setState({res:'修改状态值'})
},
render:function(){
console.log(this.props)
console.log(this.state)
return(
<div>
<h1>组件内部状态值:{this.state.res}</h1>
<button onClick={this.tap}>修改数据</button>
</div>
)
}
})
ReactDOM.render(<Demo/>,document.getElementById("out"))
属性和状态都可以传值,不同的是属性设置后在传输中不能修改,状态传值可以通过this.setState修改,但需要注意的是不能让它无触发修改,这样会造成二次渲染,浏览器会崩溃,需把这个触发放到事件函数中。
那么通过改变状态我们可以应用在页面登陆时修改密码是否可视,下面写个小的Demo:
var Demo=React.createClass({
getInitialState:function(){
return{
res:'text',
txt:'明文框'
}
},
tap:function(){
if(this.state.res=='text'){
this.setState({res:'password',txt:'密码框'})
}else{
this.setState({res:'text',txt:'明文框'})
}
},
render:function(){
return(
<div>
<input type={this.state.res} />
<button onClick={this.tap}>{this.state.txt}</button>
</div>
)
}
})
ReactDOM.render(<Demo/>,document.getElementById('out'))
React学习小结(三)的更多相关文章
- react学习小结(生命周期- 实例化时期 - 存在期- 销毁时期)
react学习小结 本文是我学习react的阶段性小结,如果看官你是react资深玩家,那么还请就此打住移步他处,如果你想给一些建议和指导,那么还请轻拍~ 目前团队内对react的使用非常普遍,之 ...
- React学习小结(一)
一.React的发展 facebook在构建instagram网站的时候遇见两个问题: 1.数据绑定的时候,大量操作真实dom,性能成本太高 2.网站的数据流向太混乱,不好控制 于是facebook起 ...
- Maven学习小结(三 基本概念)
1.Maven POM POM(Project Object Model)项目对象模型,是用Maven来管理项目里的一个叫做pom.xml的文件.所有的项目配置信息都被定义在这个文件中, 通过这个文件 ...
- React学习笔记(三) 组件传值
组件嵌套后,父组件怎么向子组件发送数据呢? 答案是: this.props <script type="text/babel"> var MyFirst = React ...
- React学习小结(二)
一.组件的嵌套 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <t ...
- javase学习小结三
格式标识符: System.out.printf("%d,%f,%5d,%-9.4f,%%,%13e",67,78.9,89,78.9,567.345); 输出结果为:67,78. ...
- React.js学习小结
最近一段时间都在学习React.js,感觉还不错,现在把自己的一些学习笔记记录一下,留着以后学习查看. 0.React全家桶(技术栈) 1.React主体 2.WebPack:grunt.gulp自动 ...
- (转)2019年 React 新手学习指南 – 从 React 学习线路图说开去
原文:https://www.html.cn/archives/10111 注:本文根据 React 开发者学习线路图(2018) 结构编写了很多新手如何学习 React 的建议.2019 年有标题党 ...
- Python 学习小结
python 学习小结 python 简明教程 1.python 文件 #!/etc/bin/python #coding=utf-8 2.main()函数 if __name__ == '__mai ...
随机推荐
- Python爬虫 URLError异常处理
1.URLError 首先解释下URLError可能产生的原因: 网络无连接,即本机无法上网 连接不到特定的服务器 服务器不存在 在代码中,我们需要用try-except语句来包围并捕获相应的异常.下 ...
- Oracle 一些基本命令
--创建表空间 --DATAFILE: 表空间数据文件存放路径 --SIZE: 起初设置为200M --空间名称MOF_TEMP与数据文件名称不要求相同,可随意命名. --AUTOEXTEND ON/ ...
- Java线程池(ThreadPool)详解
线程五个状态(生命周期): 线程运行时间 假设一个服务器完成一项任务所需时间为:T1 创建线程时间,T2 在线程中执行任务的时间,T3 销毁线程时间. 如果:T1 + T3 远大于 T2,则可以 ...
- CTF 字符统计1
题目地址:http://sec.hdu.edu.cn/question/web/1047/ 题目如下: 给你2秒钟的时间,告诉我下面这坨字符中有多少个s,多少个e,多少个c,多少个l,多少个a和多少个 ...
- java多线程基本概述(四)——死锁
package mytask; public class Task { public static void main(String[] args) { DeadThread thread = new ...
- java 集合框架(TreeSet操作,自动对数据进行排序,重写CompareTo方法)
/*TreeSet * treeSet存入数据后自动调用元素的compareTo(Object obj) 方法,自动对数据进行排序 * 所以输出的数据是经过排序的数据 * 注:compareTo方法返 ...
- Android Weekly Notes Issue #254
Android Weekly Issue #254 April 23rd, 2017 Android Weekly Issue #254 本期内容包括: 如何用Kotlin写一个Gradle Plug ...
- 根据GPS经纬度判断当前所属的市区
这个事情分两步走 1. 拿到行政区划的地理围栏数据 2. 根据GPS定位判断一个点是否落在地理围栏的多边形区域里. 1. 获取行政区划的地理围栏数据可以利用百度API.打开以前我的一个例子在chrom ...
- 初学T4模板
1.T4模板语法 <#@ template language="C#v3.5" hostSpecific="true" debug="true& ...
- [CTSC1999]【网络流24题】星际转移
Description 由于人类对自然资源的消耗,人们意识到大约在2300 年之后,地球就不能再居住了.于是在月球上建立了新的绿地,以便在需要时移民.令人意想不到的是,2177 年冬由于未知的原因,地 ...