当前位置:首页 > 技术分析 > 正文内容

如何优雅地使用JS自定义一个全局事件总线(eventBus)?

ruisui883个月前 (02-03)技术分析25

我们的项目是基于Vue3的,众所周知,Vue3中移除了全局事件总线相关的API,那么,如果我们需要的话,该如何手动实现一个呢?今天,我教大家手写一个eventBus。

首先,我们先用文档注释定义一个类型 Fn,编写良好的文档注释,可以使我们像写TypeScript一样写JavaScript。

/** @typedef {Function & { once: boolean }} Fn */

事件总线通常至少需要4个API方法,及一个对象用于存储事件名称和回调函数。首先,我们先定义存储事件和回调的对象events

export default {
    /** @type {Object

接下来,我们创建emit方法,用于发射事件。该方法可接收无限个参数,第一个参数为事件名,后面的所有参数为事件携带的数据。我们使用es6展开运算符将剩余参数以args数组接收。我们根据事件名获取到该事件名对应的回调函数数组,如果存在该数组,那么遍历它,调用所有的回调函数,如果该函数的once属性的值为true,那么我们取消对该事件的监听。

export default {
  	... ...,
    emit (evt, ...args) {
      const fns = this.events[evt]
      fns && fns.forEach(fn => {
        fn(...args)
        fn.once && this.off(evt, fn)
      })
    }
}

然后,我们创建on方法,用于监听事件。该方法接收2个参数,第一个参数为事件名,第二个参数为回调函数。该方法非常简单,就是将fn添加进eventsevt对应的回调函数数组中。

export default {
  	... ...,
    on (evt, fn) {
      this.events[evt] = [...(this.events[evt] || []), fn]
    }
}

现在,我们创建once方法,用于仅监听一次事件。该方法与on方法接收同样的参数,唯一的不同是,我们首先将fnonce属性设置为true,用于标识该回调函数仅被触发一次,然后,调用on方法。

export default {
  	... ...,
    once (evt, /** @type {Fn} */ fn) {
      fn.once = true
      this.on(evt, fn)
    }
}

最后,我们创建off方法,用于注销事件监听,该方法与on接收同样的参数,我们首先获取到eventsevt事件名对应的回调函数数组fns,如果数组存在,我们获取fnfns中的索引,如果存在,则通过移除该回调函数。

export default {
  	... ...,
    off (evt, fn) {
      const fns = this.events[evt]
      if (fns) {
        const index = fns.indexOf(fn)
        index > -1 && fns.splice(index, 1)
      }
    }
}

感谢阅读!到此已经讲解完毕,自定义全局事件总线是不是很简单?大家有什么不明之处,或有更好的实现方案,欢迎评论区见!

后续有时间的话,我会分享更多Web开发相关的技术文章,欢迎大家阅读!

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/717.html

分享给朋友:

“如何优雅地使用JS自定义一个全局事件总线(eventBus)?” 的相关文章

「2022」打算跳槽涨薪,必问面试题及答案——VUE篇

1、为什么选择VUE,解决了什么问题?vue.js 正如官网所说的,是一套构建用户界面的渐进式框架。与其它重量级框架不同的是,vue 被设计为可以自底向上逐层应用。vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另外一方面,当与现代化工具链以及各种支持类库结合使用时,vu...

Java教程:gitlab-使用入门

1 导读本教程主要讲解了GitLab在项目的环境搭建和基本的使用,可以帮助大家在企业中能够自主搭建GitLab服务,并且可以GitLab中的组、权限、项目自主操作GitLab简介GitLab环境搭建GitLab基本使用(组、权限、用户、项目)2 GitLab简介GitLab是整个DevOps生命周期...

jvm疯狂吃内存,到底是谁的锅?

jvm应该是每一个java程序员都需要掌握的内容,但是在没有遇到问题之前,很多都是基于理论的,唯有实战才能增加个人的知识储备。本文是从一个角度来分析是谁在狂吃内存,希望对你有所帮助。本文是易观技术人员注意到一台开发机上各个微服务进程占用内存很高,随即便展开了调查......ps:本文来源于:http...

壹啦罐罐 Android 手机里的 Xposed 都装了啥

这是少数派推出的系列专题,叫做「我的手机里都装了啥」。这个系列将邀请到不同的玩家,从他们各自的角度介绍手机中最爱的或是日常使用最频繁的 App。文章将以「每周一篇」的频率更新,内容范围会包括 iOS、Android 在内的各种平台和 App。本期继续歪楼,由少数派撰稿作者@壹啦罐罐介绍他正在使用的...

双子座应用程序推出模型切换器以在Android上访问2.0

#头条精品计划# 快速导读谷歌推出了Gemini 2.0 Flash实验版,现已在其安卓应用中可用,之前仅在gemini.google.com网站上提供。新版本的15.50包含模型切换器,用户可以在设置中选择不同模型,包括1.5 Pro、1.5 Flash和2.0 Flash实验版。谷歌提醒,2.0...

全新斯柯达柯珞克Karoq深度评测:大众替代品

“斯柯达柯珞克是一款出色的全能家庭 SUV,具有许多有用的功能”价格36,605 英镑- 49,190 英镑优点方便的 VarioFlex 后排座椅非常适合家庭入住驾驶乐趣缺点保修期短保守的内饰性格比Yeti少结论——斯柯达柯珞克是一辆好车吗?斯柯达柯珞克是在辉煌的七座 斯柯达柯迪亚克之后推出的,因...