react组件通信那些事儿
父组件是调用组件的组件。
现在看来,感觉父组件就是一个壳子,定义好壳子里面会有什么,而子组件是一个具体的实现,说明,会用到什么东西,如果有这些东西,会进行什么操作。总之,父组件是材料,有水和泥,子组件告诉你,怎么制作水泥。
父组件给子组件输入什么,子组件就是什么。不同的父组件调用,或许可以呈现不同的输出,前提是在子组件里面要定义不同的接口,属性方法,供不同的父组件使用。

class Parent extends React.Component {
state = {
msg: 'start'
};
componentDidMount() {
setTimeout(() => {
this.setState({
msg: 'end'
});
}, 1000);
}
render() {
return <Child_1 msg={this.state.msg} />;
}
}
class Child_1 extends React.Component {
render() {
return <p>{this.props.msg}</p>;
}
}
class Parent extends React.Component {
state = {
msg: 'start'
};
fMsg(msg) {
this.setState({
msg
});
}
render() {
return (
<div>
<p>child msg: {this.state.msg}</p>
<Child_1 transferMsg={msg => this.fMsg(msg)} />
</div>
);
}
}
class Child_1 extends React.Component {
componentDidMount() {
setTimeout(() => {
this.props.transferMsg('end');
}, 1000);
}
render() {
return (
<div>
<p>child_1 component</p>
</div>
);
}
}
class Parent extends React.Component {
state = {
msg: 'start'
};
fMsg(msg) {
this.setState({
msg
});
}
componentDidUpdate() {
console.log('Parent update');
}
render() {
return (
<div>
<Child_1 transferMsg={msg => this.fMsg(msg)} />
<Child_2 msg={this.state.msg} />
</div>
);
}
}
class Child_1 extends React.Component {
componentDidMount() {
setTimeout(() => {
this.props.transferMsg('end');
}, 1000);
}
componentDidUpdate() {
console.log('Child_1 update');
}
render() {
return (
<div>
<p>child_1 component</p>
</div>
)
}
}
class Child_2 extends React.Component {
componentDidUpdate() {
console.log('Child_2 update');
}
render() {
return (
<div>
<p>child_2 component: {this.props.msg}</p>
</div>
)
}
}
import eventProxy from '../eventProxy';
class Parent extends React.Component {
render() {
return (
<div>
<Child_1 />
<Child_2 />
</div>
);
}
}
class Child_1 extends React.Component {
componentDidMount() {
setTimeout(() => {
// 发布者,发布msg事件
eventProxy.trigger('msg', 'end');
}, 1000);
}
}
class Child_2 extends React.Component {
state = {
msg: 'start'
};
componentDidMount() {
// 订阅者,监听msg事件
eventProxy.on('msg', (msg) => {
this.setState({
msg
});
});
}
render() {
return (
<div>
<p>child_2 component: {this.state.msg}</p>
</div>
)
}
}
// 通过...运算符向Child_1_1传递Parent组件的信息
class Child_1 extends React.Component {
render() {
return (
<div>
<p>{this.props.msg}</p>
<Child_1_1 {...this.props} />
</div>
)
}
}
class Child_1_1 extends React.Component {
render() {
return <p>{this.props.msg}</p>;
}
}
class Parent extends React.Component {
getChildContext() {
return {
color: 'red',
cbFun: this.fCallback.bind(this)
};
}
fCallback(msg) {
console.log(msg);
}
render() {
return <Child_1 />;
}
}
Parent.childContextTypes = {
color: PropTypes.string,
cbFun: PropTypes.func
}
class Child_1 extends React.Component {
render() {
return <Child_1_1 />;
}
}
class Child_1_1 extends React.Component {
static contextTypes = {
color: PropTypes.string,
cbFun: PropTypes.func
}
render() {
const styles = { color: this.context.color };
const cb = (msg) => {
return () => {
this.context.cbFun(msg);
}
}
return (
<button style={styles} onClick={cb('子组件向父组件传数据。')}>点击</button>
)
}
}
class Parent extends React.Component {
constructor(props) {
super(props);
this.state = {
color: "red"
}
}
getChildContext() {
return {
color: this.state.color,
cbFun: this.fCallback.bind(this)
};
}
fCallback(color) {
this.setState({color});
}
render() {
return <Child_1 />;
}
}
Parent.childContextTypes = {
color: PropTypes.string,
cbFun: PropTypes.func
}
class Child_1 extends React.Component {
render() {
return <Child_1_1 />;
}
}
class Child_1_1 extends React.Component {
static contextTypes = {
color: PropTypes.string,
cbFun: PropTypes.func
}
render() {
const styles = { color: this.context.color };
const cb = (msg) => {
return () => {
this.context.cbFun(msg);
}
}
return (
<button style={styles} onClick={cb('blue')}>点击</button>
)
}
}
react组件通信那些事儿的更多相关文章
- react第六单元(react组件通信-父子组件通信-子父组件通信-跨级组件的传参方式-context方式的传参)
第六单元(react组件通信-父子组件通信-子父组件通信-跨级组件的传参方式-context方式的传参) #课程目标 1.梳理react组件之间的关系 2.掌握父子传值的方法 3.掌握子父传值的方法 ...
- 21.react 组件通信
状态属性可以修改 this.setState()中可以写对象,也可以写方法 <script type="text/babel"> class Test extends ...
- React/组件通信
组件通信可以分为以下几种: 父组件向子组件通信 子组件向父组件通信 跨级组件的通信及context 没有嵌套关系的组件通信 父组件向子组件通信 父组件通过props向子组件传递需要的信息. 子 ...
- vue组件通信那些事儿
一.说说通信 通信,简言之,交流信息.交流结束后,把信息放在哪里,这是一个值得思考的问题.vue中保存状态有2种方式,组件内的data属性和组件外的vuex的state属性. 1.用state的场景 ...
- 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 ...
随机推荐
- <a>之间怎么放值</a> 挺简单的,第一次遇到···
需求描述:对列表中的某一列内容添加a标签(其实就是对td标签下添加a标签了). 思路简介:拿到这个我首先的反应就是在td标签对text获取内容的代码中动态拼接<a></a>字符 ...
- Python实战二
要求:按照要求完成对文件的增.删.改.查操作. def add(**kwargs): '''新增内容,在指定位置新增''' while True: flag = False with open(&qu ...
- samba 二进制包 tar.gz 安装
一.下载 sudo wget https://download.samba.org/pub/samba/stable/samba-4.8.10.tar.gz 二.解压 sudu tar -xvzf s ...
- bzoj3991 lca+dfs序应用+set综合应用
/* 给定一棵树,树上会出现宝物,也会有宝物消失 规定如果要收集树上所有宝物,就要选择一个点开始,到每个宝物点都跑一次,然后再回到那个点 现在给定m次修改,每次修改后树上就有一个宝物消失,或者一个宝物 ...
- Nginx详解十二:Nginx场景实践篇之跨站访问相关
跨站访问 浏览器请求一个页面的时候,发送了两个域名的请求 此情况不安全,容易出现CSRF攻击,所以浏览器禁止跨域访问 Nginx设置打开跨站访问 配置语法:add_header name value ...
- 51Nod 1298 圆与三角形(计算几何)
1298 圆与三角形 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 给出圆的圆心和半径,以及三角形的三个顶点,问圆同三角形是否相交.相交输出"Yes&quo ...
- 静态属性property
静态属性property(是通过对象去使用) property是一种特殊的属性,访问它时会执行一段功能(函数)然后返回值 1 . 通过@property修饰过的函数属性,调用的时候无需在加() cla ...
- 为什么dbms_metadata.get_ddl显示不全?
http://bi.dataguru.cn/thread-335433-1-1.html
- console输出彩色字体
console.log("%c%s","color: red; background: yellow; font-size: 24px;","警告!& ...
- php让一个数组按照另外一个数组的键名进行排序
$a = [ 'id', 'name', 'identityId', 'phone', 'email', 'schoolId' ]; $b = [ 'id' => '唯一标识', 'identi ...