Vue知识分享:事件Bus

事件Bus在手 天下我有~

事件Bus是什么 ?

它是一个Vue实例 , 用作一个组件内或者页面内的事件中心总线 , 帮助组件内通信
Vue教程中是有提到 Bus的用法 , 但是因为Vuex的存在 , 它被放在了一个很不起眼的地方 .

$dispatch$broadcast 已经被弃用。请使用更多简明清晰的组件间通信和更好的状态管理方案,如:Vuex
因为基于组件树结构的事件流方式实在是让人难以理解,并且在组件结构扩展的过程中会变得越来越脆弱。这种事件方式确实不太好,我们也不希望在以后让开发者们太痛苦。并且$dispatch$broadcast 也没有解决兄弟组件间的通信问题。
对于$dispatch$broadcast最简单的升级方式就是:通过使用事件中心,允许组件自由交流,无论组件处于组件树的哪一层。由于 Vue 实例实现了一个事件分发接口,你可以通过实例化一个空的 Vue 实例来实现这个目的。
这些方法的最常见用途之一是父子组件的相互通信。在这些情况下,你可以使用 [v-on监听子组件上 emit 的变化](https://cn.vuejs.org/v2/guide/components-custom-events.html#%E5%B0%86%E5%8E%9F%E7%94%9F%E4%BA%8B%E4%BB%B6%E7%BB%91%E5%AE%9A%E5%88%B0%E7%BB%84%E4%BB%B6)。这可以允许你很方便的添加事件显性。 然而,如果是跨多层父子组件通信的话,`emit` 并没有什么用。相反,用集中式的事件中间件可以做到简单的升级。这会让组件之间的通信非常顺利,即使是兄弟组件。因为 Vue 通过事件发射器接口执行实例,实际上你可以使用一个空的 Vue 实例。

为什么有Vuex , 但我仍然要推荐用它 看一下使用场景吧
比如这个按钮

TIM截图20191004195929.png
TIM截图20191004195929.png

点击 展开后
TIM截图20191004200011.png
TIM截图20191004200011.png

它可以通过点击叉叉关闭 , 这个很简单 , 但是我也实现点击别处自动关闭 可能是点击上栏 , 可能是滑动屏幕 或者其他你所想 .
很明显这是一件一件的事情 .
你可以设置Vuex 并在不同组件中的事件设置这个开关的状态buttonOpenState为 false
但是这个开关并非看到的一个状态那么简单 , 它涉及动画,防抖等 , 可能还需要执行某个开关函数完成这个功能 , 所以我们需要先computed返回这个Vuex中的值作为本地的状态(因为watch无法监测Vuex中的值) , 然后再设置watch来监控它的变化并执行开关函数 .
为了这个开关 , 我们要向Vuex存一个用完就丢的值 , 要专门copmputed返回一个值 , 还要写一个watch来执行函数 , 虽然比一层层传值好了很多但是比较冗杂 .
再比如一个被复用的通知框 , 一个状态是是否显示 , 一个状态是通知的内容 , 这时候Vuex就需要存两个变量 . 显得非常沉迂 .
这个时候事件Bus出场了
它的原理是使用 $emit, $on, $off 分别来分发、监听、取消监听事件
首先这个 Bus 的Vue实例是独立开项目中组件的
在某个页面新建文件 eventHub.js

import Vue from 'vue'
export default new Vue();

在这个页面引入这个Vue实例然后

//eventHub就是刚刚创建的bus实例
methods: {
  addTodo: function () {
    eventHub.$emit('add-todo', { text: this.newTodoText })
    this.newTodoText = ''
  }
}
created: function () {
  eventHub.$on('add-todo', this.addTodo)
  eventHub.$on('delete-todo', this.deleteTodo)
},
// 最好在组件销毁前
// 清除事件监听
beforeDestroy: function () {
  eventHub.$off('add-todo', this.addTodo)
  eventHub.$off('delete-todo', this.deleteTodo)
},

使用emit 和on 发送 , 接受事件 . 这样子就完成了bus的功能
如果你不想每次都引入Bus实例你可以

//1.在main.js中挂载至原型链
Vue.prototype.bus = new Vue()
//2.写在Vuex里 与Vuex的模块对应
const schedule = {
    state:{
        week:0,
        Bus:new Vue(),
    },
    mutations:{
        changeWeek(state,par){
            state.week = par;
            
        }
    },
}
//3.使用依赖注入 , 一个页面把最上层的页面组件作为Bus , 
//比较推荐这种 , 写法简洁也保证一个页面一个Bus , 而且利用了Vue实例
//页面顶层组件
provide() {
      return {
        Bus: this,
      }
    },
//页面内组件
inject:['Bus'],
    created() {
        this.Bus.$on('dosomething', function(){
            ...
        });
    },
    beforeDestroy() {
        this.Bus.$off('dosomething');
    },

实际上Bus是有缺点的 , 在vue-dev-tool 调试时 , 无法知道是哪里发生了事件 ($emit) , 所以虽然它非常简洁 , 他不适合一个所有情景 , 我个人认为它是比较适合当别的组件想改变某个组件内部状态的情况 , 而组件间共享的数据 , 比如
选择星期数 , 有三四处组件需要联动改变 , 这就应该用Vuex了
Bus -> 多组件改一组件
Vuex->多组件用一数据

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容