21.react 组件通信
状态属性可以修改
this.setState()中可以写对象,也可以写方法
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
n:1
}
}
fn(){
/*this.setState({
n:this.state.n+1
});*/
/*this.setState(function(prevState,props){
console.log(prevState,props);
return {
n:prevState.n + 1
}
});*/
this.setState((prevState,props)=>({n:prevState.n + 1}));
}
render(){
return <div>
<span>{this.state.n}</span>
<input onClick={this.fn.bind(this)} type="button" value="按钮" />
</div>
}
}
ReactDOM.render(
<Test name="abc"/>,
document.getElementById("app")
);
</script>
res:

事件:
获取点击坐标
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
}
fn(ev){
console.log(1,ev);
console.log(2,ev.clientX,ev.clientY);
}
render(){
return <div>
<input onClick={this.fn.bind(this)} type="button" value="按钮" />
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
res:

事件冒泡:
没有ev.cancelBubble
用ev.stopPropagation();
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
}
div(ev){
alert("div");
}
btn(ev){
//ev.cancelBubble = true;//X 没有这个属性
//console.log( ev.cancelBubble );
ev.stopPropagation();//√
alert("btn");
}
render(){
return <div onClick={this.div.bind(this)}>
<input onClick={this.btn.bind(this)} type="button" value="按钮" />
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
默认事件:
return false;//无效
用ev.preventDefault();
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
}
fn(ev){
ev.preventDefault();
//return false;
}
render(){
return <div>
<a onClick={this.fn.bind(this)} href="http://www.baidu.com/">百度</a>
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
留言板:
留言板添加删除
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state={
msg:"",
arr:["aaa","bbb","ccc"],
}
}
show(ev){
this.setState({
msg:ev.target.value,
})
}
add(){
this.state.arr.unshift(this.state.msg);
this.setState({
arr:this.state.arr
})
}
del(index){
this.state.arr.splice(index,1);
this.setState({
arr:this.state.arr
})
}
render(){
let arr = this.state.arr;
/*let aULi = [];
for(let i = 0; i < arr.length; i++){
aULi.push(<li key={i}>{arr[i]}</li>);
}*/
let aUli = arr.map((item,index)=><li key={index}>{item}<a onClick={this.del.bind(this,index)} href="javascript:;">删除</a></li>);
return <div>
<input type="text" onInput={this.show.bind(this)}/>
<input type="button" onClick ={this.add.bind(this)} value="添加"/>
<ul>
{aUli}
</ul>
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app"),
)
</script>
res:


数据绑定:
input数据绑定,加value属性时需要加onChange事件
this.setState({
msg:ev.target.value
});
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
msg:"",
}
}
fn(ev){
this.setState({
msg:ev.target.value
});
}
render(){
return <div>
<input type="text" onInput={this.fn.bind(this)} /> <br />
<input type="text" value={this.state.msg} onChange={this.fn.bind(this)} /> <br />
{this.state.msg}
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
res:

求和:
exp1:
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
a:1,b:1
}
}
keyupHandle1(ev){
this.setState({
a:parseInt(ev.target.value),
});
}
keyupHandle2(ev){
this.setState({
b:parseInt(ev.target.value),
});
}
sumHandle(){
}
render(){
return <div>
<input type="text" onKeyUp={this.keyupHandle1.bind(this)} />
<input type="text" onKeyUp={this.keyupHandle2.bind(this)} />
<input onClick={this.sumHandle.bind(this)} type="button" value="=" />
{this.state.a + this.state.b}
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
res:

exp2:
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
a:1,b:1
}
}
sumHandle(){
let oText1 = document.getElementById("txt1");
let oText2 = document.getElementById("txt2");
this.setState({
a:parseInt(oText1.value),
b:parseInt(oText2.value)
});
}
render(){
return <div>
<input id="txt1" type="text" />
<input id="txt2" type="text" />
<input onClick={this.sumHandle.bind(this)} type="button" value="=" />
{this.state.a + this.state.b}
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
res:

exp3:
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
a:1,b:1
}
}
sumHandle(){
console.log(this.refs);
this.setState({
a:parseInt(this.refs.txt1.value),
b:parseInt(this.refs.txt2.value)
});
}
render(){
return <div>
<input ref="txt1" type="text" />
<input ref="txt2" type="text" />
<input onClick={this.sumHandle.bind(this)} type="button" value="=" />
{this.state.a + this.state.b}
</div>
}
}
ReactDOM.render(
<div>
<Test/>
<Test/>
</div>,
document.getElementById("app")
);
</script>

exp3:
<script type="text/babel">
class Test extends React.Component{
constructor(...args){
super(...args);
this.state = {
a:1,b:1
}
}
keyupHandle1(ev){
this.setState({
a:parseInt(ev.target.value),
});
}
keyupHandle2(ev){
this.setState({
b:parseInt(ev.target.value),
});
}
render(){
return <div>
<input type="text" value={this.state.a} onChange={this.keyupHandle1.bind(this)} />
<input type="text" value={this.state.b} onChange={this.keyupHandle2.bind(this)} />
<input type="button" value="=" />
{this.state.a + this.state.b}
</div>
}
}
ReactDOM.render(
<Test/>,
document.getElementById("app")
);
</script>
res:

组件通信:
父子:
父--->子
传递数据:props refs
子--->父
1、需要先把父级传递给子级
2、this.props.parent.xxx
非父子 :需要借助全局变量 缺点:乱!不易管理!
exp1:父--->子
<script type="text/babel">
class Parent extends React.Component{
constructor(...args){
super(...args);
this.state = {
name:"你好呀!"
}
}
render(){
return <div> 父组件 ----{this.state.name}
<Child name={this.state.name}/>
</div>
}
}
class Child extends React.Component{
constructor(...args){
super(...args);
}
render(){
return <div>子组件----{this.props.name}</div>
}
}
ReactDOM.render(
<Parent/>,
document.getElementById("app")
);
</script>
res:

exp2: 子--->父
parent={this}把整个父元素传过去
<script type="text/babel">
class Parent extends React.Component{
constructor(...args){
super(...args);
this.state = {
name:"你好呀!"
}
}
fn(data){
alert("父级");
this.setState({
name:data
})
}
render(){
return <div> 父组件 ----{this.state.name}
<Child name={this.state.name} parent={this} />
</div>
}
}
class Child extends React.Component{
constructor(...args){
super(...args);
}
fn(){
this.props.parent.fn(666);
}
render(){
return <div onClick={this.fn.bind(this)}>子组件----{this.props.name}</div>
}
}
ReactDOM.render(
<Parent/>,
document.getElementById("app")
);
</script>
res:



exp3:父子通信显示删除
<script type="text/babel">
let arr = [
{id:Math.random(),username:"aaa",password:"123"},
{id:Math.random(),username:"bbb",password:"123"},
{id:Math.random(),username:"ccc",password:"123"}
];
//父,列表
class UserList extends React.Component{
constructor(...args){
super(...args);
this.state = {
users:this.props.users
}
}
delHandle(id){
//alert("删除"+id);
this.setState({
users:this.state.users.filter(item => id != item.id)
});
}
render(){
let aUser = this.state.users.map((item,index)=><User key={item.id} parent={this} user={item}/>);
return <ul>
{aUser}
</ul>
}
}
//子,元素
class User extends React.Component{
constructor(...args){
super(...args);
}
fn(id){
this.props.parent.delHandle(id);
}
render(){
return <li>{this.props.user.username}-----{this.props.user.password}
<a onClick={this.fn.bind(this,this.props.user.id)} href="javascript:;">删除</a>
</li>
}
}
ReactDOM.render(
<UserList users={arr}/>,
document.getElementById("app")
);
</script>
res:


exp4:兄弟通信
点击组件2修改组件1,设置全局变量,
<script type="text/babel">
//全局变量
let a = null;
class Comp1 extends React.Component{
constructor(...args){
super(...args);
this.state = {
msg:"aaaa"
}
a=(data)=>{
//alert(1);
this.setState({
msg:data
});
}
}
render(){
return <div>组件1-----{this.state.msg}</div>
}
}
class Comp2 extends React.Component{
constructor(...args){
super(...args);
}
fn(){
a("bbb");
}
render(){
return <div onClick={this.fn.bind(this)}>组件2</div>
}
}
ReactDOM.render(
<div>
<Comp1/>
<Comp2/>
</div>,
document.getElementById("app")
);
</script>
res:


21.react 组件通信的更多相关文章
- react第六单元(react组件通信-父子组件通信-子父组件通信-跨级组件的传参方式-context方式的传参)
第六单元(react组件通信-父子组件通信-子父组件通信-跨级组件的传参方式-context方式的传参) #课程目标 1.梳理react组件之间的关系 2.掌握父子传值的方法 3.掌握子父传值的方法 ...
- react组件通信那些事儿
父组件是调用组件的组件.现在看来,感觉父组件就是一个壳子,定义好壳子里面会有什么,而子组件是一个具体的实现,说明,会用到什么东西,如果有这些东西,会进行什么操作.总之,父组件是材料,有水和泥,子组件告 ...
- React/组件通信
组件通信可以分为以下几种: 父组件向子组件通信 子组件向父组件通信 跨级组件的通信及context 没有嵌套关系的组件通信 父组件向子组件通信 父组件通过props向子组件传递需要的信息. 子 ...
- React组件通信技巧
效果图 communication.gif 点击查看Github完整源码 1.父向子通信 直接标签中插入参数即可 //number只是个例子 let _number = this.state.numb ...
- React组件通信
1.父子通信 父 -> 子 props子 -> 父 回调函数,父组件通过props向子组件传递一个函数,子组件调用函数,父组件在回调函数中用setState改变自身状态 2.跨层级通信 1 ...
- 使用reflux进行react组件之间的通信
前言 组件之间为什么要通信?因为有依赖. 那么,作为React组件,怎么通信? React官网说, 进行 父-子 通信,可以直接pass props. 进行 子-父 通信,往父组件传给子组件的函数注入 ...
- React之组件通信
组件通信无外乎,下面这三种父子组件,子父组件,平行组件(也叫兄弟组件)间的数据传输.下面我们来分别说一下: 父子组件: var Demo=React.createClass({ getInitialS ...
- 【JAVASCRIPT】React学习- 数据流(组件通信)
摘要 react 学习包括几个部分: 文本渲染 JSX 语法 组件化思想 数据流 一 组件通信如何实现 父子组件之间不存在继承关系 1.1 父=>子通信 父组件可以通过 this.refs.xx ...
- 关于react组件之间的通信
才开始学react刚好到组件通信这一块,就简单的记录下组件间的通信方式:父到子:props.context,子到父:自定义事件.回调,兄弟组件:共父props传递.自定义事件import React, ...
随机推荐
- .Net转Java.02.数据类型
.NET中常见的数据类型分类分别是值类型和引用类型 值类型包括(基元类型.struct.枚举) 引用类型包括(类.类.数组.接口.指针) Java分为,基本类型和类 C# Java 值类型 ...
- getParameter() getInputStream()和getReader() 区别 这三种方法是有冲突的,因为流只能被读一次。
我们经常用servlet和jsp, 经常用request.getParameter() 来得到数据. request.getParameter()request.getInputStream()req ...
- JavaScript中Object值合并方法
原文:https://www.cnblogs.com/fullstack-yang/p/8085206.html ------------------------------------ 前言:在日常 ...
- 高斯模糊的Java实现
1.http://jhlabs.com/ip/index.html public static byte[] blur(byte[] data) throws IOException { ByteAr ...
- Switch语句的参数是什么类型的?
在Java5以前,switch(expr)中,exper只能是byte,short,char,int类型. 从Java5开始,java中引入了枚举类型,即enum类型. 从Java7开始,exper还 ...
- Jackson 解析json数据之忽略解析字段注解@JsonIgnoreProperties
转自:http://blog.csdn.net/ngl272/article/details/70217104 以前解析json用的惯的就是Google的gson了,用惯了基本就用它了,一直也没发现什 ...
- CentOS 7.2编译安装PHP7
原文: https://typecodes.com/web/centos7compilephp7.html?utm_source=tuicool&utm_medium=referralPHP官 ...
- python 验证码识别示例(一) 某个网站验证码识别
某个招聘网站的验证码识别,过程如下 一: 原始验证码: 二: 首先对验证码进行分析,该验证码的数字颜色有变化,这个就是识别这个验证码遇到的比较难的问题,解决方法是使用PIL 中的 getpixel ...
- CentOS 7 yum nginx MySQL PHP7 简易环境搭建(精)
用centos自带的yum源来安装nginx,mysql和php,超级方便,省去编译的麻烦,省去自己配置的麻烦,还能节省非常多的时间. 我们先把yum源换成国内的阿里云镜像源(当然不换也可以),先备份 ...
- SublimeText3追踪函数工具CTags设置及使用
第一步:在 ST3 安装 CTags 插件 1. 在 ST3 快捷键 Crtl+Shift+P 然后输入 pci ,选择“ Package Control: Install Package ”启动安装 ...