react中的组件传参

1. 父组件向子组件通信

React数据流动是单向的,父组件向子组件通信也是最常见的;父组件通过props向子组件传递需要的信息。

2. 子组件向父组件通信

利用回调函数或利用自定义事件机制

3.跨级组件通信

(1)层层组件传递props

例如A组件和B组件之间要进行通信,先找到A和B公共的父组件,A先向C组件通信,C组件通过props和B组件通信,此时C组件起的就是中间件的作用

(2)使用context

context是一个全局变量,像是一个大容器,在任何地方都可以访问到,我们可以把要通信的信息放在context上,然后在其他组件中可以随意取到;
但是React官方不建议使用大量context,尽管他可以减少逐层传递,但是当组件结构复杂的时候,我们并不知道context是从哪里传过来的;而且context是一个全局变量,全局变量正是导致应用走向混乱的罪魁祸首.

4. 没有嵌套关系的组件通信

使用自定义事件机制
在componentDidMount事件中,如果组件挂载完成,再订阅事件;在组件卸载的时候,在componentWillUnmount事件中取消事件的订阅;
自定义事件是典型的发布订阅模式,通过向事件对象上添加监听器和触发事件来实现组件之间的通信。

总 结

父组件向子组件通信: props;
子组件向父组件通信: 回调函数/自定义事件;
跨级组件通信: 层层组件传递props/context;
没有嵌套关系组件之间的通信: 自定义事件。

你可能感兴趣的:(react,前端,reactjs)