Node.js —— EventEmitter

2023-12-21 15:52
文章标签 js node eventemitter

本文主要是介绍Node.js —— EventEmitter,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Node.js中,EventEmitter是一个非常重要的类,它提供了一种用于处理事件的基础框架。事件处理是Node.js中异步操作的重要组成部分,而EventEmitter则是实现事件驱动逻辑的关键。

EventEmitter的作用

  1. 事件管理:EventEmitter提供了一种统一的事件管理机制,可以将不同的事件和监听器进行绑定和解绑,确保事件和监听器之间的松散耦合。
  2. 跨组件通信:通过EventEmitter,不同组件之间可以进行通信。当一个组件需要通知其他组件时,可以触发相应的事件,并传递必要的数据。
  3. 异步操作处理:EventEmitter可以用于处理异步操作,确保异步操作完成后的回调逻辑的正确执行。
  4. 插件系统:通过EventEmitter,可以实现插件系统的扩展和升级。插件可以通过注册和触发事件与主程序进行通信,实现功能的扩展和升级。

EventEmitter的用法

  • 创建EventEmitter实例:首先,需要使用require()函数导入events模块,并使用new关键字创建一个EventEmitter实例。

const EventEmitter = require('events');  
const eventEmitter = new EventEmitter();
  • 注册事件监听器:使用EventEmitter实例的on()方法或addListener()方法来注册事件监听器。这两个方法都需要两个参数,第一个参数是事件名称,第二个参数是事件处理函数。
eventEmitter.on('event', function(arg1, arg2) {  console.log('Event triggered:', arg1, arg2);  
});
  • 触发事件:使用EventEmitter实例的emit()方法来触发事件。这个方法需要一个或多个参数,这些参数会传递给事件处理函数。
    eventEmitter.emit('event', 'Hello', 'World');
  • 移除事件监听器:如果需要移除某个事件的所有监听器,可以使用EventEmitter实例的removeAllListeners()方法。如果需要移除某个事件的某个特定监听器,可以使用EventEmitter实例的removeListener()方法。

    eventEmitter.removeAllListeners('event');  
    eventEmitter.removeListener('event', myFunction);
  • 监听器的默认限制:在默认情况下,如果添加的监听器超过10个,Node.js会输出警告信息。可以使用setMaxListeners()方法来提高监听器的默认限制数量。

    eventEmitter.setMaxListeners(20);

EventEmitter 的属性介绍

  • 方法
序号方法描述
1addListener(event, listener)
为指定事件添加一个监听器到监听器数组的尾部。
 
2on(event, listener)
为指定事件注册一个监听器,接受一个字符串 event 和一个回调函数。
eventEmitter.on('connection', function (stream) {console.log('someone connected!');
});
3once(event, listener)
为指定事件注册一个单次监听器,即 监听器最多只会触发一次,触发后立刻解除该监听器。
eventEmitter.once('connection', function (stream) {console.log('Ah, we have our first user!');
});
4removeListener(event, listener)

移除指定事件的某个监听器,监听器必须是该事件已经注册过的监听器。

它接受两个参数,第一个是事件名称,第二个是回调函数名称。

var callback = function(stream) {
  console.log('someone connected!');
};
eventEmitter .on('connection', callback);
// ...
eventEmitter .removeListener('connection', callback);
5removeAllListeners([event])
移除所有事件的所有监听器, 如果指定事件,则移除指定事件的所有监听器。
eventEmitter 
6setMaxListeners(n)
默认情况下, EventEmitters 如果你添加的监听器超过 10 个就会输出警告信息。 setMaxListeners 函数用于改变监听器的默认限制的数量。
eventEmitter 
7listeners(event)
返回指定事件的监听器数组。
eventEmitter 
8emit(event, [arg1], [arg2], [...])
按监听器的顺序执行执行每个监听器,如果事件有注册监听返回 true,否则返回 false。
eventEmitter 
  • 类方法
序号方法 描述
1listenerCount(emitter, event)返回指定事件的监听器数量。
  • 事件
序号事件 描述
1newListener
  • event - 字符串,事件名称

  • listener - 处理事件函数

该事件在添加新监听器时被触发。
2removeListener
  • event - 字符串,事件名称

  • listener - 处理事件函数

从指定监听器数组中删除一个监听器。需要注意的是,此操作将会改变处于被删监听器之后的那些监听器的索引。

Event Emitter的使用场景和作用

  1. 异步操作处理:在Node.js中,许多操作都是异步的,例如文件读取、网络请求等。通过使用EventEmitter,可以方便地处理这些异步操作的结果和回调逻辑。
  2. 插件系统:插件系统是许多应用程序的重要组成部分。通过使用EventEmitter,可以轻松地实现插件系统的扩展和升级功能,使应用程序更加灵活和可扩展。
  3. 多模块通信:在大型应用程序中,不同模块之间需要进行通信和交互。通过使用EventEmitter,可以方便地实现不同模块之间的通信和数据传递。
  4. 错误处理:在Node.js中,错误处理是非常重要的一个环节。通过使用EventEmitter,可以方便地捕获和处理错误事件,避免程序崩溃或产生不可预料的行为。
  5. 自定义事件类型:除了标准的事件类型外,开发人员还可以自定义事件类型。通过使用EventEmitter,可以轻松地定义

EventEmitter的核心方法 

EventEmitter的核心方法是emit(),它用于触发事件并传递参数给事件处理函数。以下是一个使用EventEmitter的简单示例👇

const EventEmitter = require('events');  class MyEmitter extends EventEmitter {}  const myEmitter = new MyEmitter();  myEmitter.on('event', (arg1, arg2) => {  console.log('Event triggered:', arg1, arg2);  
});  myEmitter.emit('event', 'Hello', 'World');

在这个示例中,首先导入EventEmitter模块,然后创建一个名为MyEmitter的类,它继承了EventEmitter。接下来,创建一个MyEmitter实例myEmitter,并使用on()方法注册一个事件监听器来处理名为'event'的事件。最后,使用emit()方法触发'event'事件,并传递两个参数'Hello'和'World'给事件处理函数。事件处理函数会接收到这两个参数,并打印出相应的消息。

这篇关于Node.js —— EventEmitter的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/520596

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

Node Linux相关安装

下载经编译好的文件cd /optwget https://nodejs.org/dist/v10.15.3/node-v10.15.3-linux-x64.tar.gztar -xvf node-v10.15.3-linux-x64.tar.gzln -s /opt/node-v10.15.3-linux-x64/bin/npm /usr/local/bin/ln -s /opt/nod

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

js异步提交form表单的解决方案

1.定义异步提交表单的方法 (通用方法) /*** 异步提交form表单* @param options {form:form表单元素,success:执行成功后处理函数}* <span style="color:#ff0000;"><strong>@注意 后台接收参数要解码否则中文会导致乱码 如:URLDecoder.decode(param,"UTF-8")</strong></span>

js react 笔记 2

起因, 目的: 记录一些 js, react, css 1. 生成一个随机的 uuid // 需要先安装 crypto 模块const { randomUUID } = require('crypto');const uuid = randomUUID();console.log(uuid); // 输出类似 '9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d'

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

uuid.js 使用

相关代码 import { NIL } from "uuid";/** 验证UUID* 为空 则返回 false* @param uuid* @returns {boolean}*/export function MyUUIDValidate(uuid: any): boolean {if (typeof uuid === "string" && uuid !== NIL) { //uuid