前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vue中eventBus的使用

vue中eventBus的使用

作者头像
tianyawhl
发布2019-12-12 11:07:42
7390
发布2019-12-12 11:07:42
举报
文章被收录于专栏:前端之攻略前端之攻略

使用场景: 1、兄弟组件的通信,父子组件的通信 2、不同路由的通信

针对兄弟组件的通信,父子组件的通信 新建bus.js文件

代码语言:javascript
复制
 import Vue from 'vue'
 var bus = new Vue()
 export default bus
 

在需要通信的组件中引入bus.js,一个组件触发事件,另一个组件监听事件

代码语言:javascript
复制
  import Bus from "@/assets/js/bus.js"
 子组件
     testClick(){
         alert("test")
         Bus.$emit("message","hiinew")
     },
 父组件
   mounted(){
     var _this = this
     Bus.$on("message",function(res){
      _this.message = res
     })
   }    
 

针对不同路由的通信

代码语言:javascript
复制
 需要在A组件销毁前触发事件
  beforeDestroy () {
    Bus.$emit("message","hii") 
  },
  在B组件created中接收事件
   created () {
      var _this = this     
      Bus.$on("message",function(res){
        console.log(res+"123")      
        _this.message = res
     })  
  },
  并且在B组件的销毁前解除监听 避免重复监听
   beforeDestroy () {
    Bus.$off("message")  
  },
 
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档