百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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

itomcoil 2025-04-05 19:25 10 浏览

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

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

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

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

export default {
    /** @type {Object<string, Fn[]} 存储事件和回调的对象字面量 */
 		events: {}
}

接下来,我们创建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开发相关的技术文章,欢迎大家阅读!

相关推荐

基于Python开发的家居用品外贸网站(B2B企业官网)

作为一名程序员,平时除了本职工作,我也会利用业余时间做一些兼职和副业,大部分的私活都是从某鱼和CSDN接的,有些是别人介绍的。最近刚好接到了一个外贸企业网站的开发需求,客户是一家位于深圳的家居用品公司...

摄像头视频流处理方法总结,如何掌握视频流处理技巧?

摄像头视频流处理是指其技术本质、关键处理流程和核心目标。1.视频流的定义视频流(VideoStream)是摄像头连续采集图像帧(frame),并以压缩编码格式(如H.264/H.265)传输或存储...

大学生机器人开发辅导|代码、机构到控制全链路进阶

想做机器人项目,却苦于不会硬件、算法和代码?SRTP、大创、全国竞赛动手项目无从下手?Arduino、STM32、RaspberryPi模块让你头大?想在毕业设计、创新实践、社团活动做出有亮点的机器...

OpenCV实现手势音量控制(opencv按钮)

前言:Hello大家好,我是Dream。今天来学习一下如何使用OpenCV实现手势音量控制,欢迎大家一起前来探讨学习~一、需要的库及功能介绍本次实验需要使用OpenCV和mediapipe库进行手...

DIY激光枪薄纱蟑螂!AI杀蚊子博士新作,项目已开源

萧箫发自凹非寺量子位|公众号QbitAI几个世纪来,人类都处在被蟑螂支配的恐惧中。但比蟑螂更恐怖的,是打不死还消失了的蟑螂……现在,一位博士搞出了一套自动识别并薄(爆)纱(杀)蟑螂的激光“炮...

为了杀蚊子,这位博士用树莓派DIY了一把激光枪

金磊发自凹非寺量子位报道|公众号QbitAI世人苦蚊子久矣。尤其在夏夜,耳边嗡嗡作响,甚至还得与其“挑灯夜战”个三百回合。为此,一个国外博士便DIY了一种高端的杀蚊方式:计算机视觉精准定...

草根PLC革命:低价魔改开源方案对决高价LabVIEW工业视觉系统!

魔改方案:三菱FX5U+树莓派魔改架构硬件清单创新设计:双核协同架构:PLC负责实时控制+树莓派运行AI算法EtherCAT菊花链:省交换机成本,布线效率提升70%五大开源工具:CODESYSR...

机器人开发进阶:看懂这五个项目中的软硬件哲学

DIY机器人项目正逐渐成为技术爱好者和创客们的热门选择。无论是用于教育、娱乐还是实际应用,机器人技术都展现了其强大的潜力。本文将介绍五个EEWorld上备受工程师关注的五个DIY项目,通过本文,您将深...

树莓派到底是什么?能干什么?有必要买吗?

很多人疑惑,树莓派到底是什么?能干什么?有必要买吗?今天我带着这三个疑惑给大家解答;一、树莓派到底是什么?树莓派通俗的理解就是一台便携式小型电脑,起码最新的树莓派4当一台电脑是可以的;往深了说,他可以...

用腾讯优图AI视觉模组做一个驾驶疲劳监测仪

道路千万条,安全第一条,相信每个人都是牢记于心的,“喝酒不开车,开车不喝酒”其实不难,难的是防范始料未及的事件,疲倦就是众多始料未及事件中,杀伤力稳居前排的,前一秒心里还在想坚持坚持,下一秒可能就失去...

Z410升级树莓派4B机型终于和大家见面了

*Z410-4B入门二次开发平台*经过近1年的反复测试,Z410升级树莓派4B的机型终于和大家见面了!Z410机型设计的初衷,就是想为大家提供一款基础的、开源的、高性价比、可扩展、可进行二次开发的无人...

有保险柜怕不安全,用树莓派制作一款只有刷脸才能开的保险柜吧

眨眨眼睛就能保住身家,好过记住密码或拿着钥匙,你的脸就是保险柜的钥匙!这个作品将展示给大家如何用树莓派和摄像头制作一个人脸识别的保险柜,当然,如果不慎毁容或整容,不好意思。。。直接拿锤子砸了吧软件部分...

项目分享|仅需1板卡+1摄像头,3步完成人脸喜怒哀乐识别

使用OpenCV、TensorFlow和Keras,基于RaspberryPi进行情绪识别,你的心情一览无余。面部表情识别系统可用于多种应用,可以用来研究或分析人的情绪。许多公司正在植入...

价值8美元的OpenAsk收费问题回答:孩子小学五年级如何入门编程?

从今天起,给大家持续更新OpenAsk上的一些收费问题的回答系列,内容信不信由你,但是如果您仔细看了分析后会说,真香。#少儿编程是智商税吗#“更多内容欢迎关注-司马南柯一梦”(欢迎随意转发)下面是一位...

再见 Pycharm,这款开箱即用的轻量级神器你值得拥有

作者:豆豆来源:Python技术如果你问我最好用的IDE是什么,那我肯定会毫不犹豫的告诉你Pycharm。毕竟jetbrains出品必属精品。但对于很多初学者来讲,Pycharm显得略笨...