【Angular】eventDispatcher详解

eventDispatcher 是一种设计模式,用于在对象之间传递事件。它允许对象订阅和发布事件,从而实现松耦合的通信机制。以下是一个详细的解释和示例代码。

1. 基本概念

  • 事件(Event):一个动作或状态变化,可以被触发和监听。
  • 发布者(Publisher):触发事件的对象。
  • 订阅者(Subscriber):监听并响应事件的对象。
  • 事件分发器(Event Dispatcher):管理事件的发布和订阅,确保事件从发布者传递到订阅者。

2. 示例代码

假设我们有一个简单的事件分发器,用于在对象之间传递消息。

typescript 复制代码
// 定义事件类型
type EventType = 'message';

// 定义事件数据类型
interface EventData {
  message: string;
}

// 定义事件处理函数类型
type EventHandler = (data: EventData) => void;

// 事件分发器类
class EventDispatcher {
  private listeners: { [key in EventType]?: EventHandler[] } = {};

  // 订阅事件
  on(event: EventType, handler: EventHandler): void {
    if (!this.listeners[event]) {
      this.listeners[event] = [];
    }
    this.listeners[event]?.push(handler);
  }

  // 取消订阅事件
  off(event: EventType, handler: EventHandler): void {
    if (this.listeners[event]) {
      this.listeners[event] = this.listeners[event]?.filter(h => h !== handler);
    }
  }

  // 触发事件
  emit(event: EventType, data: EventData): void {
    if (this.listeners[event]) {
      this.listeners[event]?.forEach(handler => handler(data));
    }
  }
}

// 使用示例
const eventDispatcher = new EventDispatcher();

// 定义一个事件处理函数
const handleMessage = (data: EventData) => {
  console.log(`Received message: ${data.message}`);
};

// 订阅事件
eventDispatcher.on('message', handleMessage);

// 触发事件
eventDispatcher.emit('message', { message: 'Hello, World!' });

// 取消订阅事件
eventDispatcher.off('message', handleMessage);

// 再次触发事件,此时不会有任何输出
eventDispatcher.emit('message', { message: 'Another message' });

3. 解释

  1. 定义事件类型和数据类型

    • EventType:定义了事件的类型。
    • EventData:定义了事件的数据类型。
  2. 定义事件处理函数类型

    • EventHandler:定义了事件处理函数的类型。
  3. 事件分发器类

    • listeners:存储事件及其对应的处理函数列表。
    • on:订阅事件,将处理函数添加到事件的处理函数列表中。
    • off:取消订阅事件,从事件的处理函数列表中移除处理函数。
    • emit:触发事件,调用所有订阅该事件的处理函数。
  4. 使用示例

    • 创建一个 EventDispatcher 实例。
    • 定义一个事件处理函数 handleMessage
    • 订阅 message 事件。
    • 触发 message 事件,打印消息。
    • 取消订阅 message 事件。
    • 再次触发 message 事件,此时不会有输出。

通过这种方式,你可以轻松地在对象之间传递事件,并且可以灵活地添加和移除事件处理函数。

相关推荐
sunny_26 分钟前
💥 Claude Code 源码泄露?我把这个最强 AI Coding Agent 的架构扒干净了
前端·agent·claude
西洼工作室31 分钟前
React轮播图优化:通过延迟 + 动画的组合,彻底消除视觉上的闪烁感
前端·react.js·前端框架
yaaakaaang40 分钟前
(八)前端,如此简单!---五组结构
前端·javascript
我是若尘44 分钟前
我的需求代码被主干 revert 了,接下来我该怎么操作?
前端·后端·代码规范
魁首1 小时前
Claude Code 源码泄露的背后,到底与Codex,Gemini 有啥不一样?
前端·openai·claude
攀登的牵牛花1 小时前
程序员失业论,被 SWE-CI 一组数据打醒:真正先被替代的是低质量交付
前端·github
EstherNi2 小时前
vue3仿照elementui样式的写法,并进行校验,并且有默认值的设置
javascript·elementui
BumBle2 小时前
Vue项目中实现路由守卫自动取消Pending请求
前端
gCode Teacher 格码致知2 小时前
Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生
开发语言·前端·javascript·node.js·jquery
竹林8182 小时前
从ethers.js迁移到Viem:我在一个DeFi项目前端重构中踩过的坑
前端·javascript