iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue3中的事件总线怎么使用
  • 748
分享到

Vue3中的事件总线怎么使用

2023-07-06 01:07:54 748人浏览 薄情痞子
摘要

本篇内容介绍了“vue3中的事件总线怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事件总线的本质Vue2中的$on、$once、$e

本篇内容介绍了“vue3中的事件总线怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

事件总线的本质

Vue2中的$on$once$emit本质上就是其内部实现了一个EventEmitter(事件派发器),每一个事件都和若干回调相对应,只要事件被触发,那么就将执行此事件所有对应的回调。同时,在javascript中,该思想被广泛地使用,尤其在node.js的事件机制中,就是创建了一个EventEmitter实例,具体请自行查阅相关资料。因此,我们只需要实现一个简单的EventEmitter,并全局传递到每一个组件中,就可以实现一个事件总线了。而全局传递,我们可以使用config.globalProperties绑定到每一个组件,也可以在根组件(main)中,通过provide提供总线,需要使用的组件使用inject注入。下面就让我们来实现一下吧。

构建一个EventEmitter

由于我们可能会有多条总线,我们还是把EventEmitter写成类的方式,每一条总线都将是一个EventEmitter实例。以下是EventEmitter的简单实现,其只实现了ononceemit三个api

class EventEmitter{    constructor(){        this.callbacks={};    }    on(envetName,callback){        if(!Array.isArray(this.callbacks[envetName])){            this.callbacks[envetName]=[];        }        this.callbacks[envetName].push(callback);    }    emit(eventName,...args){        if(Array.isArray(this.callbacks[eventName])){            this.callbacks[eventName].forEach(callback=>callback(...args));        }    }    off(eventName,callback){        if(!Array.isArray(this.callbacks[eventName])){            return        }        if(callback){            this.callbacks[eventName].forEach(cb=>{                if(callback===cb){                    this.callbacks[eventName].splice(this.callbacks[eventName].indexOf(callback),1);                }            });        } else{            this.callbacks[eventName]=[];        }    }    once(eventName,callback){        const that=this;        const fn=function(){            callback.apply(that,[...arguments]);            that.off(eventName,fn);        }        that.on(eventName,fn);    }}

将EventEmitter实例化并全局引入

config.globalProperties方法

在main.js

import { createApp } from 'vue'import './style.CSS'import App from './App.vue'const app=createApp(App);app.config.globalProperties.$event=new EventEmitter();app.mount('#app')

在组件中:

//Comp1<script setup>import {getCurrentInstance} from "vue"const vm=getCurrentInstance();vm.proxy.$event.on('test',()=>{    console.log('test event emit!')})</script>//Comp2<script setup>import {getCurrentInstance} from "vue"const vm=getCurrentInstance();vm.proxy.$event.emit('test',"a","b")</script>

但这种方法不太优雅,不方便定义多条总线,建议使用下述的方法。

provide/inject

在main.js中

provide("eventBus1",new EventEmitter());provide("eventBus2",new EventEmitter());

在组件中

//Comp1<script setup>import {inject} from "vue";const bus1=inject("eventBus1")bus1.on("bus1-on-event",()=>{    console.log('eventBus1 on event emit!')})</script>//Comp2<script setup>import {inject} from "vue";const bus1=inject("eventBus1")const bus2=inject("eventBus2")bus2.on("bus2-on-event",()=>{    console.log('eventBus2 on event emit!')})bus1.emit("bus1-on-event")</script>//Comp3<script setup>import {inject} from "vue";const bus2=inject("eventBus2")bus2.emit("bus2-on-event")</script>

此方法中,使用inject也比使用getCurrentInstance.proxy更优雅一些,且不使用就不必使用inject注入。

“Vue3中的事件总线怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Vue3中的事件总线怎么使用

本文链接: https://www.lsjlt.com/news/356908.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue3中的事件总线怎么使用
    本篇内容介绍了“Vue3中的事件总线怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事件总线的本质Vue2中的$on、$once、$e...
    99+
    2023-07-06
  • Vue3中事件总线的具体使用
    目录导读事件总线的本质构建一个EventEmitterconfig.globalProperties方法provide/inject结束语导读 在Vue2中,我们遇到复杂的组件通信时...
    99+
    2023-05-15
    Vue3 事件总线 Vue 事件总线
  • vue3+ts使用bus事件总线的示例代码
    1、在vue2中我是这样使用的 //创建一个vueBus.js import Bus from 'vue'; let install = function (Vue) { Vue.p...
    99+
    2024-04-02
  • Vue组件的自定义事件和全局事件总线怎么使用
    这篇“Vue组件的自定义事件和全局事件总线怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件的自定义事件和全局...
    99+
    2023-07-05
  • react中可不可以使用事件总线
    本篇文章和大家了解一下react中可不可以使用事件总线。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 react中可以使用事件总线;react使用事件总线可以...
    99+
    2024-04-02
  • Vue中事件总线(eventBus)的深入详解及使用
    目录1. 简介2. 使用安装及引入在组件中使用补充:移除监听事件总结1. 简介 Vue 组件中常见的有:父子组件通信、兄弟组件通信。而父子组件通信就很简单,父组件会通过 props ...
    99+
    2024-04-02
  • android事件总线EventBus3.0使用方法详解
    一.EventBus概述 1.EventBus的三要素EventBus有三个主要的元素需要我们先了解一下:Event:事件,可以是任意类型的对象。Subscriber:事件订阅者,在EventBus3.0之前消息处理的方法只能限定于onEv...
    99+
    2023-05-30
    android 事件总线 eventbus3.0
  • 详解Vue3中Watch监听事件的使用
    目录一、watch的使用1、引入watch2、多个数据源监听3、监听数组变化4、侦听对象5、结论一、watch的使用 watch(WatcherSource, Callback, [...
    99+
    2023-02-10
    Vue3 Watch监听事件使用 Vue3 Watch监听 Vue3 Watch
  • Flutter EventBus事件总线的应用详解
    目录前言EventBus的简介EventBus的实际应用总结前言 flutter项目中,有许多可以实现跨组件通讯的方案,其中包括InheritedWidget,Notificatio...
    99+
    2024-04-02
  • vue篇之事件总线EventBus使用示例详解
    目录正文父子组件通讯原则EventBus的简介如何使用EventBus初始化发送事件接收事件移除事件监听者全局EventBus创建全局EventBus总结正文 许多现代JavaScr...
    99+
    2024-04-02
  • Vue全局事件总线是什么
    这篇文章主要为大家展示了“Vue全局事件总线是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue全局事件总线是什么”这篇文章吧。全局事件总线,是组件间的一种通信方式,适用于任何组件间通信。...
    99+
    2023-06-29
  • Vue eventBus事件总线封装后再用怎么实现
    今天小编给大家分享一下Vue eventBus事件总线封装后再用怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2023-07-02
  • ABP框架中的事件总线功能介绍
    目录事件总线关于事件总线为什么需要这个东西事件总线创建过程订阅事件事件发布事件全局异常加入事件总线功能创建事件订阅事件发布事件测试记录事件事件总线 关于事件总线 ABP 中,为了方便...
    99+
    2024-04-02
  • Vue3的事件处理和修饰符怎么定义使用
    本篇内容介绍了“Vue3的事件处理和修饰符怎么定义使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Vue事件处理是每个Vue项目的必要方面...
    99+
    2023-07-04
  • vue3中怎么使用vue-codemirror插件
    本文小编为大家详细介绍“vue3中怎么使用vue-codemirror插件”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue3中怎么使用vue-codemirror插件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知...
    99+
    2023-07-06
  • Vue3中的异步组件defineAsyncComponentAPI怎么使用
    传递工厂函数作为参数defineAsyncComponent方法接收一个工厂函数是它的基本用法,这个工厂函数必须返回一个Promise,Promise的resolve应该返回一个组件。我们这里以Vue Cli创建的项目为例,这里我稍微做了一...
    99+
    2023-05-21
    Vue3
  • Vue2中如何使用全局事件总线实现任意组件间通信
    目录前言: 一:什么是全局事件总线 二:全局事件总线怎么创建 三:绑定自定义事件四:触发自定义事件五:解绑自定义事件总结前言:  vue 中组...
    99+
    2022-12-28
    vue组件之间通信 vue组件通信 vue组件之间如何通信
  • Vue eventBus事件总线封装后再用的方式
    目录前言空vue实例构建的事件总线简单的方式复杂又简单的方式总结前言 现在的项目中是不是在使用 eventbus 的时候,还有很多人都是直接创建一个vue 实例直接使用的,哪里需要哪...
    99+
    2024-04-02
  • Vue3插件中怎么使用Provide和Inject
    今天小编给大家分享一下Vue3插件中怎么使用Provide和Inject的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。为什么...
    99+
    2023-07-04
  • Vue3中的watch怎么使用
    这篇文章主要介绍“Vue3中的watch怎么使用”,在日常操作中,相信很多人在Vue3中的watch怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3中的watch怎么使用”的疑惑有所帮助!接下来...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作