vue组件中传值EventBus的使用及注意事项说明
#代码知识 发布时间: 2026-01-12
主要想说下非父子组件之间的通信。

项目场景:
在app.vue里写了一个公共的顶部导航navbar,然后右侧有个分享按钮,而这个分享按钮只有在特定的页面才展示,项目里是在lottery.vue页面,然后想实现app.vue里点击分享按钮,触发lottery.vue里的分享方法。
解决:使用eventBus
1、创建一个event-bus.js
import Vue from 'vue'
export const EventBus = new Vue()
2、在app.vue引入eventbus,点击分享按钮时触发方法
import { EventBus } from '@/tools/event-bus'
onClickRight () {
EventBus.$emit('handleLotteryShare')
}
3、在lottery.vue引入eventBus,在mounted里监听
import { EventBus } from '@/tools/event-bus'
mounted () {
EventBus.$on('handleLotteryShare', () => {
this.doShare()
})
},
4、到此解决了。但是,但是,出bug了,每多点击一次,分享的弹窗的蒙层颜色就更深一层。然后一头雾水,以为是原生app里api的bug,跑去问他们,结果尴尬了,并不是,而是调了多次分享接口。
然后就发现应该跟eventBus有关,上网搜索了下,原来eventBus用完要记得解绑。加上以下代码解决了。
created () {
// 解绑bus
EventBus.$off('handleLotteryShare')
}
使用eventBus注意事项:要记得解绑啊!EventBus.$off('handleLotteryShare')。
补充知识:vue前端兄弟组件或任意两个组件之间进行传值可以使用eventbus
具体使用流程如下:
1、定义一个js文件,引入Vue
2、在需要使用eventbus的组件中引入步骤1创建的js文件
bus.$emit进行传值
3、在另一个组件中使用bus.$on进行接收
其中,msg即为步骤2中emit携带的参数“123”
以上这篇vue组件中传值EventBus的使用及注意事项说明就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
代码知识SEO上一篇 : C#开发中常用的加密解密方法汇总
下一篇 : Golang操作MySql数据库的完整步骤记录
-
SEO外包最佳选择国内专业的白帽SEO机构,熟知搜索算法,各行业企业站优化策略!
SEO公司
-
可定制SEO优化套餐基于整站优化与品牌搜索展现,定制个性化营销推广方案!
SEO套餐
-
SEO入门教程多年积累SEO实战案例,从新手到专家,从入门到精通,海量的SEO学习资料!
SEO教程
-
SEO项目资源高质量SEO项目资源,稀缺性外链,优质文案代写,老域名提权,云主机相关配置折扣!
SEO资源
-
SEO快速建站快速搭建符合搜索引擎友好的企业网站,协助备案,域名选择,服务器配置等相关服务!
SEO建站
-
快速搜索引擎优化建议没有任何SEO机构,可以承诺搜索引擎排名的具体位置,如果有,那么请您多注意!专业的SEO机构,一般情况下只能确保目标关键词进入到首页或者前几页,如果您有相关问题,欢迎咨询!