Vue 兄弟组件之间的通信

92 篇文章 3 订阅

Vue 兄弟组件之间的通信

参考:https://blog.csdn.net/weixin_39763493/article/details/107182252

1. Vue中实现兄弟组件的通讯一般为2种方式:

  1. 一种方法是让父组件允当两个子组件之间的中间件(中继)
  2. 另一种就是使用EventBus(事件总线),它允许两个子组件之间直接通讯,而不需要涉及父组件。

由于中继方式比较简单,这里不做赘述,只讲EventBus方式。

2. EventBus具体实现

  1. 首先在main.js文件中定义一个新的bus对象并且挂载在原型链上,其实他是一个全新的Vue实例:
Vue.prototype.$bus = new Vue()
  1. 兄弟组件 a.js 中,声明并监听事件 brotherEvent
created(){
	this.$bus.$on('brotherEvent', res=>{
		console.log(res) // 得到123
	})
}
  1. 兄弟组件 b.js 中,触发 $bus 中的brotherEvent
methods:{
	bAction(){
		this.$bus.$emit('brotherEvent', ’123‘)
	}
}
  • 4
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清风细雨_林木木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值