当前位置:首页 > JavaScript

js简单实现订阅事件

2026-04-04 20:00:30JavaScript

实现订阅事件的基本模式

使用自定义事件和回调函数列表来管理订阅者:

class EventEmitter {
  constructor() {
    this.events = {};
  }

  on(eventName, callback) {
    if (!this.events[eventName]) {
      this.events[eventName] = [];
    }
    this.events[eventName].push(callback);
  }

  emit(eventName, ...args) {
    const callbacks = this.events[eventName];
    if (callbacks) {
      callbacks.forEach(cb => cb(...args));
    }
  }

  off(eventName, callback) {
    const callbacks = this.events[eventName];
    if (callbacks) {
      this.events[eventName] = callbacks.filter(cb => cb !== callback);
    }
  }
}

使用示例

创建事件发射器实例并订阅事件:

const emitter = new EventEmitter();

function handleData(data) {
  console.log('Received:', data);
}

emitter.on('data', handleData);
emitter.emit('data', { value: 123 });  // 输出: Received: {value: 123}
emitter.off('data', handleData);

浏览器环境实现

利用DOM的EventTarget接口实现:

const eventTarget = new EventTarget();

function handleClick(e) {
  console.log('Event triggered:', e.detail);
}

eventTarget.addEventListener('customClick', handleClick);
eventTarget.dispatchEvent(new CustomEvent('customClick', {
  detail: { x: 10, y: 20 }
}));
eventTarget.removeEventListener('customClick', handleClick);

基于Promise的订阅

实现一次性事件订阅:

function once(eventEmitter, eventName) {
  return new Promise(resolve => {
    const handler = (...args) => {
      eventEmitter.off(eventName, handler);
      resolve(args);
    };
    eventEmitter.on(eventName, handler);
  });
}

// 使用方式
once(emitter, 'data').then(data => {
  console.log('One-time event:', data);
});

支持异步事件的变体

处理异步事件回调:

js简单实现订阅事件

class AsyncEventEmitter extends EventEmitter {
  async emitAsync(eventName, ...args) {
    const callbacks = this.events[eventName] || [];
    for (const cb of callbacks) {
      await cb(...args);
    }
  }
}

每种实现方式适用于不同场景,基础版EventEmitter适合大多数简单用例,DOM EventTarget适用于浏览器环境,Promise版本适合需要等待单次事件触发的场景。

标签: 事件简单
分享给朋友:

相关文章

jquery触发事件

jquery触发事件

jQuery 触发事件的方法 jQuery 提供了多种方法来触发事件,包括直接触发、自定义事件以及模拟用户行为。以下是几种常见的方法: trigger() 方法 trigger() 方法用于触发指定…

vue 实现简单登录

vue 实现简单登录

实现 Vue 简单登录功能 创建登录组件 在 Vue 项目中创建一个登录组件 Login.vue,包含用户名和密码输入框以及登录按钮。 <template> <div clas…

vue实现简单登录

vue实现简单登录

使用 Vue 实现简单登录功能 创建 Vue 项目 确保已安装 Vue CLI,通过以下命令创建新项目: vue create vue-login-demo 选择默认配置或手动配置(如 Babel、…

vue实现简单对话

vue实现简单对话

Vue实现简单对话功能 数据绑定与列表渲染 使用Vue的v-for指令渲染对话列表,结合v-model实现输入框双向绑定: <template> <div> &l…

vue实现拖拽事件

vue实现拖拽事件

Vue 实现拖拽事件的方法 使用 HTML5 原生拖拽 API HTML5 提供了原生的拖拽 API,可以通过 draggable 属性、dragstart、dragend、dragover 和 dr…

vue实现后退事件

vue实现后退事件

监听浏览器后退事件 在Vue中可以通过window.onpopstate或beforeRouteLeave路由守卫实现后退事件监听。以下是两种常用方法: 方法一:使用window.onpopstat…