- 父子组件之间通信
- 兄弟组件之间的通信
- 祖孙与后代组件之间的通信
- 非关系组件间的通信
整理vue
中8种常规的通信方案
- 通过 props 传递
- 通过 $emit 触发自定义事件
- 使用 ref
- EventBus
- $parent 或$root
- attrs 与 listeners
- Provide 与 Inject
- Vuex
组件通信方案:
- 通过props传递
- 通过$emit触发自定义事件
- 使用ref
- EventBus
- $parent或$root
- attrs与listeners
- Provide与inject
- Vuex
props传递数据
- 适用场景:父组件传递数据给子组件
- 子组件设置props属性,定义接收父组件传递过来的参数
- 父组件在使用子组件标签中通过字面量来传递值
Children.vue
1 | props:{ |
Father.vue
1 | <Children name='jack' age=18/> |
$emit触发自定义事件
- 适用场景:子组件传递数据给父组件
- 子组件通过$emit触发自定义事件,$emit第二个参数为传递的数值
- 父组件绑定监听器获取子组件传递过来的参数
- 与组件和 prop 一样,事件名提供了自动的大小写转换。如果在子组件中触发一个以 camelCase (驼峰式命名) 命名的事件,你将可以在父组件中添加一个 kebab-case (短横线分隔命名) 的监听器。
Children.vue
methods中
1 | this.$emit('add',good) |
Father.vue
template中:
1 | <Children @add="cartAdd($event)" |
ref
父组件在使用子组件的时候设置ref
父组件通过这只子组件ref来获取数据
父组件
1 | <Children ref='foo'/> |
EventBus
- 使用场景:兄弟组件传值
- 创建一个中央事件总线EventBus
- 兄弟组件通过$emit触发自定义事件,$emit第二个参数为传递的数值
- 另一个兄弟组件通过$on监听自定义事件
Bus.js
1 | class Bus{ |
在入口中执行挂载
1 | //main.js |
在组件中引入并使用
1 | export default{ |
在setup中使用
setup中无法访问到应用实例的this,所以用provide/inject
1 | import {inject} from 'vue' |
$parent或$root
通过共同父辈$parent或者$root搭建通信桥梁
兄弟组件
this.$parent.on(‘add’,this.add);
另一个兄弟组件
this.$parent.emit(‘add’)
$attrs 与$ listeners
- 适用场景:祖先传递数据给子孙
- 设置批量向下传属性
$attrs
和$listeners
- 包含了父级作用域中不作为
prop
被识别 (且获取) 的特性绑定 ( class 和 style 除外)。 - 可以通过
v-bind="$attrs"
传⼊内部组件
在vue2.4中,为了解决该需求,引入了$attrs
和$listeners
,新增了inheritAttrs
选项。我们只需要在B组件中对引入的C组件增加下面两个属性即可绑定所有的属性和事件。
1 | <C v-bind="$attrs" v-on="$listeners"></C> |
A组件
1 | <template> |
B组件
1 | <template> |
C组件
1 | <template> |
参考:https://juejin.cn/post/6844903828098138120
provide与inject
在祖先组件定义provide属性,并返回传递的值
在后代组件通过inject接收组件传递过来的值
祖先组件:
1 | provide(){ |
后代组件:
1 | inject:['foo'];//获取到祖先组件传递过来的值 |
Vuex
- 适用场景: 复杂关系的组件数据传递
Vuex
作用相当于一个用来存储共享变量的容器state
用来存放共享变量的地方getter
,可以增加一个getter
派生状态,(相当于store
中的计算属性),用来获得共享变量的值mutations
用来存放修改state
的方法。actions
也是用来存放修改state的方法,不过action
是在mutations
的基础上进行。常用来做一些异步操作
#小结
- 父子关系的组件数据传递选择
props
与$emit
进行传递,也可选择ref
- 兄弟关系的组件数据传递可选择
$bus
,其次可以选择$parent
进行传递 - 祖先与后代组件数据传递可选择
attrs
与listeners
或者Provide
与Inject
- 复杂关系的组件数据传递可以通过
vuex
存放共享的变量