vue bus触发$emit 监听$on 关闭$off传值

本文介绍了一种使用Vue实例作为事件总线实现组件间通信的方法。通过在main.js中引入并暴露bus实例,允许不同组件注册监听事件和发射事件,从而实现跨组件的数据传输。文章详细展示了如何在a.vue和b.vue组件中利用Bus实例进行事件监听和事件触发,完成数据的传递。
// bus.js文件
import Vue from 'vue';
export default new Vue;
// main.js文件
**** // 原有的数据
**** // 原有的数据
import bus from '@/bus.js';
Vue.prototype.Bus = bus;
//a.vue 
...
 beforeCreate(){
    Bus.$on("this_change",[1,2])
 }
....
//b.vue
...
created(){
    Bus.$emit("this_change",(em) => {
        //这样就可以打印出来刚刚传过来的1和2了
        console.log(em[1],em[2]); 
    });
}beforeDestroy(){
    //最后不要忘了删除传输事件
    Bus.$off("this_change")

评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值