在 Vue.js中优雅地使用全局事件的方法


Posted in Javascript onFebruary 01, 2019

Vue 2.0 版本中取消了 v1 中的 $broadcast 方法,因此要使用全局事件时,不可避免地会使用到 event-bus 之类的方法,本文旨在提出一种不需要用到 event-bus 的全局事件使用方法。

主要思路是将事件全部绑定在 $root 上,并为所有全局事件添加一个前缀防止冲突,再通过向 $options 上注入新的 key 来简化使用方式。

以下为 mixin 文件代码

// event-mixin.js
export default {
 created() {
  if (this.$options.events) {
   Object.keys(this.$options.events).forEach(key => {
    let handler = this.$options.events[key]
    if (typeof handler === 'string') {
     handler = this[handler]
    }
    this[key + '::handler'] = handler.bind(this)
    this.$root.$on('global::' + key, this[key + '::handler'])
   })
  }
 },
 beforeDestroy() {
  if (this.$options.events) {
   Object.keys(this.$options.events).forEach(key => {
    this.$root.$off('global::' + key, this[key + '::handler'])
   })
  }
 }
}

使用前先在 main.js 中调用 mixin

Vue.mixin(require('./event-mixin.js').default)
在各个组件中,向 $root 发送事件即可

// a.vue
export default {
  name: 'a',
  events: {
    'evt.a': 'handlerA',
    'evt.b'() {
      console.log('B triggered')
    }
  },
  methods: {
    handlerA() {
      console.log('A triggered')
    }
  }
}
// b.vue
export default {
  name: 'b',
  events: {
    'evt.b'() {
      console.log('B triggered again')
    }
  }
}
// c.vue
export default {
  name: 'c',
  created() {
    this.$root.$emit('global::evt.a') // 'A triggered'
    this.$root.$emit('global::evt.b', 'data') // 'B triggered', 'B triggered again'
    // 使用以上方式触发,也可以在 mixin 中向实例添加专用触发方法
  }
}

使用这种方法,可以避免新建专门用于传输事件的 vue 实例,编写回调函数时也更容易管理。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用ajax+jqtransform实现动态加载select
Dec 01 Javascript
js实现鼠标划过给div加透明度的方法
May 25 Javascript
JavaScript使用键盘输入控制实现数字验证功能
Aug 19 Javascript
jQuery Ajax使用FormData对象上传文件的方法
Sep 07 Javascript
Easyui的组合框的取值与赋值
Oct 28 Javascript
jQuery插件FusionCharts实现的Marimekko图效果示例【附demo源码】
Mar 24 jQuery
vue-router实现组件间的跳转(参数传递)
Nov 07 Javascript
Vue项目使用CDN优化首屏加载问题
Apr 01 Javascript
vue引入axios同源跨域问题
Sep 27 Javascript
H5+C3+JS实现五子棋游戏(AI篇)
May 28 Javascript
js实现点击烟花特效
Oct 14 Javascript
原生js拖拽功能制作滑动条实例代码
Feb 05 Javascript
微信小程序实现的动态设置导航栏标题功能示例
Jan 31 #Javascript
JS双向链表实现与使用方法示例(增加一个previous属性实现)
Jan 31 #Javascript
JS基于对象的链表实现与使用方法示例
Jan 31 #Javascript
JS栈stack类的实现与使用方法示例
Jan 31 #Javascript
JQuery中queue方法用法示例
Jan 31 #jQuery
JavaScript两种计时器的实例讲解
Jan 31 #Javascript
JavaScript对JSON数组简单排序操作示例
Jan 31 #Javascript
You might like
php+ajax无刷新分页实例详解
2015/12/07 PHP
简单实现php上传文件功能
2017/09/21 PHP
精解window.setTimeout()&window.setInterval()使用方式与参数传递问题!
2007/11/23 Javascript
jQuery $.each的用法说明
2010/03/22 Javascript
关于juqery radio写法的兼容性问题(新老版本jquery)
2010/06/14 Javascript
ie下$.getJSON出现问题的解决方法
2014/02/12 Javascript
js浏览器本地存储store.js介绍及应用
2014/05/13 Javascript
ECharts仪表盘实例代码(附源码下载)
2016/02/18 Javascript
使用JavaScript解决网页图片拉伸问题(推荐)
2016/11/25 Javascript
js 判断数据类型的几种方法
2017/01/13 Javascript
微信小程序 页面滑动事件的实例详解
2017/10/12 Javascript
Vuejs在v-for中,利用index来对第一项添加class的方法
2018/03/03 Javascript
vue项目持久化存储数据的实现代码
2018/10/01 Javascript
vue使用Google地图的实现示例代码
2018/12/19 Javascript
p5.js实现动态图形临摹
2019/10/23 Javascript
js里面的变量范围分享
2020/07/18 Javascript
[45:59]EG vs OG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
机器学习之KNN算法原理及Python实现方法详解
2018/07/09 Python
python实发邮件实例详解
2019/11/11 Python
Python使用socket_TCP实现小文件下载功能
2020/10/09 Python
在pycharm中使用pipenv创建虚拟环境和安装django的详细教程
2020/11/30 Python
html5 canvas-1.canvas介绍(hello canvas)
2013/01/07 HTML / CSS
中国跨境电商:Tomtop
2017/03/16 全球购物
FLOS美国官网:意大利高级照明工艺的传奇
2018/08/07 全球购物
澳大利亚在线消费电子产品商店:TobyDeals
2020/01/05 全球购物
.NET remoting的两种通道是什么
2016/05/31 面试题
什么是View State?
2013/01/27 面试题
中软国际Java程序员机试题
2012/08/19 面试题
人力资源管理专业毕业生推荐信
2013/11/07 职场文书
大学生党课思想汇报
2013/12/29 职场文书
写自荐信三大法宝
2014/01/24 职场文书
2014年中班元旦活动方案
2014/02/14 职场文书
网络技术专业推荐信
2014/02/20 职场文书
新年团拜会主持词
2014/04/02 职场文书
微信小程序APP的事件绑定以及传递参数时的冒泡和捕获
2022/04/19 Javascript
macos系统如何实现微信双开? mac登录两个微信以上微信的技巧
2022/07/23 数码科技