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 ...
随机推荐
- 深入Web请求过程
B/S网络架构 带来的好处: 1.客户端使用同一的浏览器. --浏览器的交互特性使其使用起来非常简便 2.服务器基于统一的http. --简化.规范开发模式,大大节省开发成本.如tomcat ngi ...
- JS常用特效方法总结
1.按Ctrl提交 <body onkeydown="if(event.ctrlKey&&event.keyCode=='13') form1.submit.click ...
- Visual Studio中的TabControl控件的用法
今天遇到了一个自己没遇到过的控件TabControl控件,所以找了点关于它的资料 TabControl属性 DisplayRect:只定该控件客户区的一个矩形 HotTrack:设置当鼠标经过页标签 ...
- 开源的C#实现WebSocket协议客户端和服务器websocket-sharp组件解析
很久没有写博客了(至少自己感觉很长时间没有写了),没办法啊,楼主也是需要生活的人啊,这段一直都在找工作什么的.(整天催我代码的人,还望多多谅解啊,我会坚持写我们的项目的,还是需要相信我的,毕竟这是一个 ...
- jenkins+webhook+docker做持续集成
简介:我们现在都流行把项目封装成docker的镜像,不过实际用的时候就会发现很麻烦,我们每次更改代码了以后都要打包成docker容器 ,事实证明项目比较多的时候真的会让人崩溃,我这边用spring c ...
- 最近公共祖先LCA(Tarjan算法)的思考和算法实现
LCA 最近公共祖先 Tarjan(离线)算法的基本思路及其算法实现 小广告:METO CODE 安溪一中信息学在线评测系统(OJ) //由于这是第一篇博客..有点瑕疵...比如我把false写成了f ...
- Mac下安装BeautifulSoup
1.输入命令su,输入root密码,进入root用户 2.执行命令安装pip: sudo easy_install pip 详细pip介绍:http://blog.csdn.net/olanlanxi ...
- pwm最后的解释
之前学东西总是模模糊糊,前几天看了pwm,虽然知道怎么配置,但是如果让我自己去写一个pwm的程序,我却不知如何下手. 不知道如何配置他的频率和占空比.今天痛定思痛,决定彻底搞懂pwm. 百度给 的答案 ...
- Java 工具类—日期获得,随机数,系统命令,数据类型转换
package tems; import java.text.SimpleDateFormat; import java.util.Arrays; import java.util.Calendar; ...
- Asp.Net 网站一键部署技术(上)
用垃圾而不稳定的网速上传N次压缩包都传不上去? 手动决定哪些覆盖不覆盖? 覆盖了web.config又要手动修改连接字符串? 不注意把原有配置搞丢了? …… 貌似从此早下班和休假与你无缘了. 所以!! ...