Vue同级组件数据传递

最近工作中遇到朋友问我Vue同级兄弟组件怎么传递数据和接收数据,平时大量用到的都是父组件和子组件传递数据,于是查了一下资料,自己写了个简单的Deom,算是了解学习了这个知识点。

1、用到的文件说明:

demo.vue、eventBus.js、first.vue、second.vue

文件关系说明:first.vue、second.vue作为组件放到demo.vue中,first.vue、second.vue是两个平级兄弟页面作为组件嵌入到demo.vue中,下文有说明。

1.1、功能点如图所示:


ps:当点击组件一的按钮,把数据传送给组件二,组件二接收到内容后,把红色文字替换掉

2、同级组件不能直接传值,需要一个中间桥梁,这里我们定义个中间桥梁js文件,命名为eventBus.js

2.1、代码如下:


2.2、demo.vue 页面代码如下


demo.vue 主要是引入了first.vue 与 second.vue 两个页面当做组件。

2.3、first.vue 页面代码如下


引入 eventBus.js,$emit触发方法 【userDefinedEvent】,这个方法是自定义的,组件二接收的时候也用这个方法即可。

2.4、second.vue 页面代码如下


引入 eventBus.js,$on接收 【userDefinedEvent】方法传过来的回调参数。

点击按钮,页面效果如下


红色文字已经修改成我们传递过来的值。


一般大型的项目,推荐使用Vuex来管理组件之间的通信





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值