React 组件通信的方式

本文介绍了React中组件间通信的常见方式,包括父组件通过props向子组件传值,子组件通过回调函数向父组件传值,以及使用中间人模式处理兄弟组件间的通信。此外,还提及了ContextAPI作为数据共享的解决方案,允许组件树下层直接访问数据,避免层层传递props。
摘要由CSDN通过智能技术生成

组件直接的通信方式:

1.父组件传值给子组件

方法:React中父组件向子组件传值,通过props自定义属性;

原理:将父组件中的数据及相关值通过自定义属性的方式,传值给子组件,也就是子组件自定义props属性名,然后,子组件通过props属性接收父组件传递的数据

2.子组件传值给父组件

原理:(通过回调函数)

方法:在子组件中自定义属性props接收父组件的方法名,在子组件通过this.props.属性名接收获取到的父组件中的方法,然后调用(this.props.属性名(参数…)),回调函数(去调用父组件中的方法),方法中的参数传值给父组件接收;(父组件方法形参接收子组件传递的实参)

3.兄弟组件传值

原理:使用中间人模式

方法:子组件传值给父组件,父组件再传给另一个子组件

Context:不必频繁的通过组件树的逐层传递props;(给组件设置了数据提供者,然后逐层以下的组件,可以直接获取给提供者的数据)

作为了解,因为React框架中提供了数据共享的方式

内部数据用state,用setState更新

外部传值用props(只读)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值