码迷,mamicode.com
首页 > 其他好文 > 详细

vue组件中传值EventBus的使用及注意事项

时间:2020-05-08 16:22:30      阅读:61      评论:0      收藏:0      [点我收藏+]

标签:应该   const   export   传值   click   strong   har   created   多点   

主要想说下非父子组件之间的通信。

项目场景:在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的使用及注意事项

标签:应该   const   export   传值   click   strong   har   created   多点   

原文地址:https://www.cnblogs.com/qiufang/p/12850814.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!