iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaScript如何实现事件总线
  • 737
分享到

JavaScript如何实现事件总线

2023-06-30 17:06:07 737人浏览 薄情痞子
摘要

这篇文章主要讲解了“javascript如何实现事件总线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript如何实现事件总线”吧!介绍Event Bus 事件总线,通

这篇文章主要讲解了“javascript如何实现事件总线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript如何实现事件总线”吧!

    介绍

    Event Bus 事件总线,通常作为多个模块间的通信机制,相当于一个事件管理中心,一个模块发送消息,其它模块接受消息,就达到了通信的作用。

    比如,Vue 组件间的数据传递可以使用一个 Event Bus 来通信,也可以用作微内核插件系统中的插件和核心通信。

    原理

    Event Bus 本质上是采用了发布-订阅的设计模式,比如多个模块 ABC 订阅了一个事件 EventX,然后某一个模块 X 在事件总线发布了这个事件,那么事件总线会负责通知所有订阅者 ABC,它们都能收到这个通知消息,同时还可以传递参数。

    JavaScript如何实现事件总线

    分析

    如何使用 JavaScript 来实现一个简单版本的 Event Bus

    • 首先构造一个 EventBus 类,初始化一个空对象用于存放所有的事件

    • 在接受订阅时,将事件名称作为 key 值,将需要在接受发布消息后执行的回调函数作为 value 值,由于一个事件可能有多个订阅者,所以这里的回调函数要存储成列表

    • 在发布事件消息时,从事件列表里取得指定的事件名称对应的所有回调函数,依次触发执行即可

    以下是代码详细实现,可以复制到谷歌浏览器控制台直接运行检测效果。

    代码

    class EventBus {  constructor() {    // 初始化事件列表    this.eventObject = {};  }  // 发布事件  publish(eventName) {    // 取出当前事件所有的回调函数    const callbackList = this.eventObject[eventName];    if (!callbackList) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let callback of callbackList) {      callback();    }  }  // 订阅事件  subscribe(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      this.eventObject[eventName] = [];    }    // 存储订阅者的回调函数    this.eventObject[eventName].push(callback);  }}// 测试const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", () => {  console.log("模块A");});eventBus.subscribe("eventX", () => {  console.log("模块B");});eventBus.subscribe("eventX", () => {  console.log("模块C");});// 发布事件eventXeventBus.publish("eventX");// 输出> 模块A> 模块B> 模块C

    上面我们实现了最基础的发布和订阅功能,实际应用中,还可能有更进阶的需求。

    进阶

    1. 如何在发送消息时传递参数

    发布者传入一个参数到 EventBus 中,在 callback 回调函数执行的时候接着传出参数,这样每一个订阅者就可以收到参数了。

    代码

    class EventBus {  constructor() {    // 初始化事件列表    this.eventObject = {};  }  // 发布事件  publish(eventName, ...args) {    // 取出当前事件所有的回调函数    const callbackList = this.eventObject[eventName];    if (!callbackList) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let callback of callbackList) {      // 执行时传入参数      callback(...args);    }  }  // 订阅事件  subscribe(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      this.eventObject[eventName] = [];    }    // 存储订阅者的回调函数    this.eventObject[eventName].push(callback);  }}// 测试const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", (obj, num) => {  console.log("模块A", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块B", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块C", obj, num);});// 发布事件eventXeventBus.publish("eventX", { msg: "EventX published!" }, 1);// 输出> 模块A {msg: 'EventX published!'} 1> 模块B {msg: 'EventX published!'} 1> 模块C {msg: 'EventX published!'} 1

    2. 订阅后如何取消订阅

    有时候订阅者只想在某一个时间段订阅消息,这就涉及带取消订阅功能。我们将对代码进行改造。

    首先,要实现指定订阅者取消订阅,每一次订阅事件时,都生成唯一一个取消订阅的函数,用户直接调用这个函数,我们就把当前订阅的回调函数删除。

    // 每一次订阅事件,都生成唯一一个取消订阅的函数const unSubscribe = () => {  // 清除这个订阅者的回调函数  delete this.eventObject[eventName][id];};

    其次,订阅的回调函数列表使换成对象结构存储,为每一个回调函数设定一个唯一 id, 注销回调函数的时候可以提高删除的效率,如果还是使用数组的话需要使用 split 删除,效率不如对象的 delete

    代码

    class EventBus {  constructor() {    // 初始化事件列表    this.eventObject = {};    // 回调函数列表的id    this.callbackId = 0;  }  // 发布事件  publish(eventName, ...args) {    // 取出当前事件所有的回调函数    const callbackObject = this.eventObject[eventName];    if (!callbackObject) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let id in callbackObject) {      // 执行时传入参数      callbackObject[id](...args);    }  }  // 订阅事件  subscribe(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this.eventObject[eventName] = {};    }    const id = this.callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this.eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this.eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this.eventObject[eventName]).length === 0) {        delete this.eventObject[eventName];      }    };    return { unSubscribe };  }}// 测试const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", (obj, num) => {  console.log("模块A", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块B", obj, num);});const subscriberC = eventBus.subscribe("eventX", (obj, num) => {  console.log("模块C", obj, num);});// 发布事件eventXeventBus.publish("eventX", { msg: "EventX published!" }, 1);// 模块C取消订阅subscriberC.unSubscribe();// 再次发布事件eventX,模块C不会再收到消息了eventBus.publish("eventX", { msg: "EventX published again!" }, 2);// 输出> 模块A {msg: 'EventX published!'} 1> 模块B {msg: 'EventX published!'} 1> 模块C {msg: 'EventX published!'} 1> 模块A {msg: 'EventX published again!'} 2> 模块B {msg: 'EventX published again!'} 2

    3. 如何只订阅一次

    如果一个事件只发生一次,通常也只需要订阅一次,收到消息后就不用再接受消息。

    首先,我们提供一个 subscribeOnce 的接口,内部实现几乎和 subscribe 一样,只有一个地方有区别,在 callbackId 前面的加一个字符 d,用来标示这是一个需要删除的订阅。

    // 标示为只订阅一次的回调函数const id = "d" + this.callbackId++;

    然后,在执行回调函数后判断当前回调函数的 id 有没有标示,决定我们是否需要删除这个回调函数。

    // 只订阅一次的回调函数需要删除if (id[0] === "d") {  delete callbackObject[id];}

    代码

    class EventBus {  constructor() {    // 初始化事件列表    this.eventObject = {};    // 回调函数列表的id    this.callbackId = 0;  }  // 发布事件  publish(eventName, ...args) {    // 取出当前事件所有的回调函数    const callbackObject = this.eventObject[eventName];    if (!callbackObject) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let id in callbackObject) {      // 执行时传入参数      callbackObject[id](...args);      // 只订阅一次的回调函数需要删除      if (id[0] === "d") {        delete callbackObject[id];      }    }  }  // 订阅事件  subscribe(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this.eventObject[eventName] = {};    }    const id = this.callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this.eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this.eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this.eventObject[eventName]).length === 0) {        delete this.eventObject[eventName];      }    };    return { unSubscribe };  }  // 只订阅一次  subscribeOnce(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this.eventObject[eventName] = {};    }    // 标示为只订阅一次的回调函数    const id = "d" + this.callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this.eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this.eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this.eventObject[eventName]).length === 0) {        delete this.eventObject[eventName];      }    };    return { unSubscribe };  }}// 测试const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", (obj, num) => {  console.log("模块A", obj, num);});eventBus.subscribeOnce("eventX", (obj, num) => {  console.log("模块B", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块C", obj, num);});// 发布事件eventXeventBus.publish("eventX", { msg: "EventX published!" }, 1);// 再次发布事件eventX,模块B只订阅了一次,不会再收到消息了eventBus.publish("eventX", { msg: "EventX published again!" }, 2);// 输出> 模块A {msg: 'EventX published!'} 1> 模块C {msg: 'EventX published!'} 1> 模块B {msg: 'EventX published!'} 1> 模块A {msg: 'EventX published again!'} 2> 模块C {msg: 'EventX published again!'} 2

    4. 如何清除某个事件或者所有事件

    我们还希望通过一个 clear 的操作来将指定事件的所有订阅清除掉,这个通常在一些组件或者模块卸载的时候用到。

      // 清除事件  clear(eventName) {    // 未提供事件名称,默认清除所有事件    if (!eventName) {      this.eventObject = {};      return;    }    // 清除指定事件    delete this.eventObject[eventName];  }

    和取消订阅的逻辑相似,只不过这里统一处理了。

    代码

    class EventBus {  constructor() {    // 初始化事件列表    this.eventObject = {};    // 回调函数列表的id    this.callbackId = 0;  }  // 发布事件  publish(eventName, ...args) {    // 取出当前事件所有的回调函数    const callbackObject = this.eventObject[eventName];    if (!callbackObject) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let id in callbackObject) {      // 执行时传入参数      callbackObject[id](...args);      // 只订阅一次的回调函数需要删除      if (id[0] === "d") {        delete callbackObject[id];      }    }  }  // 订阅事件  subscribe(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this.eventObject[eventName] = {};    }    const id = this.callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this.eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this.eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this.eventObject[eventName]).length === 0) {        delete this.eventObject[eventName];      }    };    return { unSubscribe };  }  // 只订阅一次  subscribeOnce(eventName, callback) {    // 初始化这个事件    if (!this.eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this.eventObject[eventName] = {};    }    // 标示为只订阅一次的回调函数    const id = "d" + this.callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this.eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this.eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this.eventObject[eventName]).length === 0) {        delete this.eventObject[eventName];      }    };    return { unSubscribe };  }  // 清除事件  clear(eventName) {    // 未提供事件名称,默认清除所有事件    if (!eventName) {      this.eventObject = {};      return;    }    // 清除指定事件    delete this.eventObject[eventName];  }}// 测试const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", (obj, num) => {  console.log("模块A", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块B", obj, num);});eventBus.subscribe("eventX", (obj, num) => {  console.log("模块C", obj, num);});// 发布事件eventXeventBus.publish("eventX", { msg: "EventX published!" }, 1);// 清除eventBus.clear("eventX");// 再次发布事件eventX,由于已经清除,所有模块都不会再收到消息了eventBus.publish("eventX", { msg: "EventX published again!" }, 2);// 输出> 模块A {msg: 'EventX published!'} 1> 模块B {msg: 'EventX published!'} 1> 模块C {msg: 'EventX published!'} 1> eventX not found!

    5. typescript 版本

    鉴于现在 TypeScript 已经被大规模采用,尤其是大型前端项目,我们简要的改造为一个 TypeScript 版本

    可以复制以下代码到 TypeScript Playground 体验运行效果

    代码

    interface ICallbackList {  [id: string]: Function;}interface IEventObject {  [eventName: string]: ICallbackList;}interface ISubscribe {  unSubscribe: () => void;}interface IEventBus {  publish<T extends any[]>(eventName: string, ...args: T): void;  subscribe(eventName: string, callback: Function): ISubscribe;  subscribeOnce(eventName: string, callback: Function): ISubscribe;  clear(eventName: string): void;}class EventBus implements IEventBus {  private _eventObject: IEventObject;  private _callbackId: number;  constructor() {    // 初始化事件列表    this._eventObject = {};    // 回调函数列表的id    this._callbackId = 0;  }  // 发布事件  publish<T extends any[]>(eventName: string, ...args: T): void {    // 取出当前事件所有的回调函数    const callbackObject = this._eventObject[eventName];    if (!callbackObject) return console.warn(eventName + " not found!");    // 执行每一个回调函数    for (let id in callbackObject) {      // 执行时传入参数      callbackObject[id](...args);      // 只订阅一次的回调函数需要删除      if (id[0] === "d") {        delete callbackObject[id];      }    }  }  // 订阅事件  subscribe(eventName: string, callback: Function): ISubscribe {    // 初始化这个事件    if (!this._eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this._eventObject[eventName] = {};    }    const id = this._callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this._eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this._eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this._eventObject[eventName]).length === 0) {        delete this._eventObject[eventName];      }    };    return { unSubscribe };  }  // 只订阅一次  subscribeOnce(eventName: string, callback: Function): ISubscribe {    // 初始化这个事件    if (!this._eventObject[eventName]) {      // 使用对象存储,注销回调函数的时候提高删除的效率      this._eventObject[eventName] = {};    }    // 标示为只订阅一次的回调函数    const id = "d" + this._callbackId++;    // 存储订阅者的回调函数    // callbackId使用后需要自增,供下一个回调函数使用    this._eventObject[eventName][id] = callback;    // 每一次订阅事件,都生成唯一一个取消订阅的函数    const unSubscribe = () => {      // 清除这个订阅者的回调函数      delete this._eventObject[eventName][id];      // 如果这个事件没有订阅者了,也把整个事件对象清除      if (Object.keys(this._eventObject[eventName]).length === 0) {        delete this._eventObject[eventName];      }    };    return { unSubscribe };  }  // 清除事件  clear(eventName: string): void {    // 未提供事件名称,默认清除所有事件    if (!eventName) {      this._eventObject = {};      return;    }    // 清除指定事件    delete this._eventObject[eventName];  }}// 测试interface IObj {  msg: string;}type PublishType = [IObj, number];const eventBus = new EventBus();// 订阅事件eventXeventBus.subscribe("eventX", (obj: IObj, num: number, s: string) => {  console.log("模块A", obj, num);});eventBus.subscribe("eventX", (obj: IObj, num: number) => {  console.log("模块B", obj, num);});eventBus.subscribe("eventX", (obj: IObj, num: number) => {  console.log("模块C", obj, num);});// 发布事件eventXeventBus.publish("eventX", { msg: "EventX published!" }, 1);// 清除eventBus.clear("eventX");// 再次发布事件eventX,由于已经清除,所有模块都不会再收到消息了eventBus.publish<PublishType>("eventX", { msg: "EventX published again!" }, 2);// 输出[LOG]: "模块A",  {  "msg": "EventX published!"},  1[LOG]: "模块B",  {  "msg": "EventX published!"},  1[LOG]: "模块C",  {  "msg": "EventX published!"},  1[WRN]: "eventX not found!"

    6. 单例模式

    在实际使用过程中,往往只需要一个事件总线就能满足需求,这里有两种情况,保持在上层实例中单例和全局单例。

    保持在上层实例中单例

    将事件总线引入到上层实例使用,只需要保证在一个上层实例中只有一个 EventBus,如果上层实例有多个,意味着有多个事件总线,但是每个上层实例管控自己的事件总线。

    首先在上层实例中建立一个变量用来存储事件总线,只在第一次使用时初始化,后续其他模块使用事件总线时直接取得这个事件总线实例。

    代码

    // 上层实例class LWEBApp {  private _eventBus?: EventBus;  constructor() {}  public getEventBus() {    // 第一次初始化    if (this._eventBus == undefined) {      this._eventBus = new EventBus();    }    // 后续每次直接取唯一一个实例,保持在LWebApp实例中单例    return this._eventBus;  }}// 使用const eventBus = new LWebApp().getEventBus();

    全局单例

    有时候我们希望不管哪一个模块想使用我们的事件总线,我们都想这些模块使用的是同一个实例,这就是全局单例,这种设计能更容易统一管理事件。

    写法同上面的类似,区别是要把 _eventBus 和 getEventBus 转为静态属性。使用时无需实例化 EventBusTool 工具类,直接使用静态方法就行了。

    代码

    // 上层实例class EventBusTool {  private static _eventBus?: EventBus;  constructor() {}  public static getEventBus(): EventBus {    // 第一次初始化    if (this._eventBus == undefined) {      this._eventBus = new EventBus();    }    // 后续每次直接取唯一一个实例,保持全局单例    return this._eventBus;  }}// 使用const eventBus = EventBusTool.getEventBus();

    感谢各位的阅读,以上就是“JavaScript如何实现事件总线”的内容了,经过本文的学习后,相信大家对JavaScript如何实现事件总线这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    --结束END--

    本文标题: JavaScript如何实现事件总线

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

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

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

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

    下载Word文档
    猜你喜欢
    • JavaScript如何实现事件总线
      这篇文章主要讲解了“JavaScript如何实现事件总线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript如何实现事件总线”吧!介绍Event Bus 事件总线,通...
      99+
      2023-06-30
    • JavaScript实现事件总线(Event Bus)的方法详解
      目录介绍原理分析进阶1. 如何在发送消息时传递参数2. 订阅后如何取消订阅3. 如何只订阅一次4. 如何清除某个事件或者所有事件5. TypeScript 版本6. 单例模式总结介绍...
      99+
      2024-04-02
    • javascript如何实现事件绑定
      小编给大家分享一下javascript如何实现事件绑定,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
      99+
      2024-04-02
    • Vue2中如何使用全局事件总线实现任意组件间通信
      目录前言: 一:什么是全局事件总线 二:全局事件总线怎么创建 三:绑定自定义事件四:触发自定义事件五:解绑自定义事件总结前言:  vue 中组...
      99+
      2022-12-28
      vue组件之间通信 vue组件通信 vue组件之间如何通信
    • 详解c# 事件总线
      目录简介实现事件总线定义事件基类定义事件参数基类定义EventBus使用事件总线事件及事件参数定义发布者定义订阅者实际使用总结简介 事件总线是对发布-订阅模式的一种实现,是一种集中...
      99+
      2024-04-02
    • javascript如何实现按钮点击事件
      本篇内容介绍了“javascript如何实现按钮点击事件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先,我们需要在 HTML 文件中创建...
      99+
      2023-07-06
    • Vue eventBus事件总线封装后再用怎么实现
      今天小编给大家分享一下Vue eventBus事件总线封装后再用怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
      99+
      2023-07-02
    • Android如何实现消息总线
      这篇文章主要介绍“Android如何实现消息总线”,在日常操作中,相信很多人在Android如何实现消息总线问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Android如何实现消息总线”的疑惑有所帮助!接下来...
      99+
      2023-07-02
    • javascript如何实现自定义事件功能
      这篇文章主要介绍了javascript如何实现自定义事件功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。概述自定义事件很难派上用场?为什么...
      99+
      2024-04-02
    • JavaScript中事件循环总结
      这篇文章主要讲解了“JavaScript中事件循环总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中事件循环总结”吧!js中的事件循环因为JavaScript是单线程的...
      99+
      2023-06-20
    • vue事件总线取消了吗
      今天小编给大家分享一下vue事件总线取消了吗的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。vue3取消了全局事件总线,废除原...
      99+
      2023-07-04
    • vue事件总线废除了吗
      本教程操作环境:windows7系统、vue3版,DELL G3电脑。vue3取消了全局事件总线,原因是安全性低。vue的全局事件总线全局事件总线,是一个全局任意组件通信技术。顾名思义,任意组件间通信,均可实现。它通信是通过一个傀儡去实现的...
      99+
      2023-05-14
      事件总线 vue3 Vue
    • JavaScript如何实现全屏和退出全屏事件
      这篇文章给大家分享的是有关JavaScript如何实现全屏和退出全屏事件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。代码如下:window.isflsgrn =&nb...
      99+
      2024-04-02
    • Vue全局事件总线是什么
      这篇文章主要为大家展示了“Vue全局事件总线是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue全局事件总线是什么”这篇文章吧。全局事件总线,是组件间的一种通信方式,适用于任何组件间通信。...
      99+
      2023-06-29
    • Javascript 中怎么实现事件流和事件委托
      今天就跟大家聊聊有关Javascript 中怎么实现事件流和事件委托,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。javascript 事件流和事件...
      99+
      2024-04-02
    • JavaScript中如何实现事件冒泡与时间捕获
      小编给大家分享一下JavaScript中如何实现事件冒泡与时间捕获,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、事件冒泡与事件捕获当我们在Web页面单击某一个元素的时候,比如某个p元素...
      99+
      2024-04-02
    • javascript如何去除事件
      这篇文章主要介绍javascript如何去除事件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! javascript去除事件的方法:1、创建一个单击事件;...
      99+
      2024-04-02
    • javascript的事件流怎么实现
      这篇文章主要讲解了“javascript的事件流怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的事件流怎么实现”吧! ...
      99+
      2024-04-02
    • Vue全局事件总线你了解吗
      全局事件总线,是组件间的一种通信方式,适用于任何组件间通信。 看下面具体的例子。 父组件:App <template> <div class="app"&g...
      99+
      2024-04-02
    • Flutter EventBus事件总线的应用详解
      目录前言EventBus的简介EventBus的实际应用总结前言 flutter项目中,有许多可以实现跨组件通讯的方案,其中包括InheritedWidget,Notificatio...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作