欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node.js中的EventEmitter類使用小結(jié)

 更新時(shí)間:2023年12月15日 10:44:55   作者:陽(yáng)光_你好  
EventEmitter 是 Node.js 中的一個(gè)核心模塊,它提供了一種實(shí)現(xiàn)事件驅(qū)動(dòng)編程的機(jī)制,它是一個(gè)基于觀察者模式的類,用于在應(yīng)用程序中處理事件和觸發(fā)事件,這篇文章主要介紹了Node.js中的EventEmitter類介紹,需要的朋友可以參考下

1.EventEmitter類說明

EventEmitter 是 Node.js 中的一個(gè)核心模塊,它提供了一種實(shí)現(xiàn)事件驅(qū)動(dòng)編程的機(jī)制。它是一個(gè)基于觀察者模式的類,用于在應(yīng)用程序中處理事件和觸發(fā)事件。
Node.js 所有的異步 I/O 操作在完成時(shí)都會(huì)發(fā)送一個(gè)事件到事件隊(duì)列。
Node.js 里面的許多對(duì)象都會(huì)分發(fā)事件:一個(gè) net.Server 對(duì)象會(huì)在每次有新連接時(shí)觸發(fā)一個(gè)事件, 一個(gè) fs.readStream 對(duì)象會(huì)在文件被打開的時(shí)候觸發(fā)一個(gè)事件。 所有這些產(chǎn)生事件的對(duì)象都是 events.EventEmitter 的實(shí)例。

2.EventEmitter類使用

2.1事件注冊(cè)和觸發(fā)

通過 on 方法可以注冊(cè)事件監(jiān)聽器,監(jiān)聽特定的事件。當(dāng)事件觸發(fā)時(shí),所有注冊(cè)的監(jiān)聽器將按照順序執(zhí)行。例如:

const EventEmitter = require('events');
const myEmitter = new EventEmitter();
myEmitter.on('event', () => {
  console.log('Event occurred');
});
myEmitter.emit('event'); // 執(zhí)行事件并觸發(fā)監(jiān)聽器

當(dāng) event 事件觸發(fā)時(shí),EventEmitter 將調(diào)用相應(yīng)的監(jiān)聽器函數(shù),并輸出 'Event occurred'。

2.2一次性事件監(jiān)聽器

使用 once 方法可以注冊(cè)一次性事件監(jiān)聽器,它只會(huì)在當(dāng)前事件觸發(fā)的第一次執(zhí)行。例如:

const EventEmitter = require('events');
const myEmitter = new EventEmitter();
myEmitter.once('event', () => {
  console.log('Event occurred once');
});
myEmitter.emit('event'); // 執(zhí)行事件并觸發(fā)監(jiān)聽器
myEmitter.emit('event'); // 不再觸發(fā)監(jiān)聽器

在上述示例中,once 方法注冊(cè)的監(jiān)聽器只會(huì)在第一次觸發(fā)事件時(shí)執(zhí)行。第二次觸發(fā)事件時(shí),不會(huì)調(diào)用該監(jiān)聽器。

2.3傳遞參數(shù)

可以在事件觸發(fā)時(shí)向監(jiān)聽器傳遞參數(shù)。例如:

const EventEmitter = require('events');
const myEmitter = new EventEmitter();
myEmitter.on('event', (arg1, arg2) => {
  console.log(`Received ${arg1} and ${arg2}`);
});
myEmitter.emit('event', 'Hello', 'World'); // 執(zhí)行事件并觸發(fā)監(jiān)聽器,并傳遞參數(shù)

在上述示例中,emit 方法觸發(fā)了 event 事件,并將 'Hello''World' 作為參數(shù)傳遞給監(jiān)聽器函數(shù)。

2.4錯(cuò)誤處理

EventEmitter 具有內(nèi)置的錯(cuò)誤處理機(jī)制??梢酝ㄟ^監(jiān)聽 'error' 事件來處理錯(cuò)誤。如果沒有針對(duì) 'error' 事件注冊(cè)監(jiān)聽器,將會(huì)輸出一個(gè)未處理的錯(cuò)誤堆棧。例如:

const EventEmitter = require('events');
const myEmitter = new EventEmitter();
myEmitter.on('error', (error) => {
  console.error('Error occurred:', error);
});
myEmitter.emit('error', new Error('Something went wrong')); // 觸發(fā) 'error' 事件并傳遞錯(cuò)誤對(duì)象

在上述示例中,當(dāng) 'error' 事件觸發(fā)時(shí),注冊(cè)的監(jiān)聽器將打印出錯(cuò)誤信息。

EventEmitter 類還具有其他方法,如 removeListener、removeAllListeners 等,用于添加、刪除或清除事件監(jiān)聽器。通過使用 EventEmitter,可以輕松實(shí)現(xiàn)事件驅(qū)動(dòng)的編程范式,以構(gòu)建靈活、可擴(kuò)展的應(yīng)用程序。

3.EventEmitter類方法說明

3.1 方法

  • addListener(event, listener):為指定事件添加一個(gè)監(jiān)聽器到監(jiān)聽器數(shù)組的尾部。
  • on(event, listener):為指定事件注冊(cè)一個(gè)監(jiān)聽器,接受一個(gè)字符串 event 和一個(gè)回調(diào)函數(shù)。
server.on('connection', function (stream) {
  console.log('someone connected!');
});

once(event, listener):為指定事件注冊(cè)一個(gè)單次監(jiān)聽器,即 監(jiān)聽器最多只會(huì)觸發(fā)一次,觸發(fā)后立刻解除該監(jiān)聽器。

server.once('connection', function (stream) {
  console.log('Ah, we have our first user!');
});

removeListener(event, listener):移除指定事件的某個(gè)監(jiān)聽器,監(jiān)聽器必須是該事件已經(jīng)注冊(cè)過的監(jiān)聽器。它接受兩個(gè)參數(shù),第一個(gè)是事件名稱,第二個(gè)是回調(diào)函數(shù)名稱。

var callback = function(stream) {
  console.log('someone connected!');
};
server.on('connection', callback);
// ...
server.removeListener('connection', callback);
  • removeAllListeners([event]):移除所有事件的所有監(jiān)聽器, 如果指定事件,則移除指定事件的所有監(jiān)聽器。
  • setMaxListeners(n):默認(rèn)情況下, EventEmitters 如果你添加的監(jiān)聽器超過 10 個(gè)就會(huì)輸出警告信息。 setMaxListeners 函數(shù)用于改變監(jiān)聽器的默認(rèn)限制的數(shù)量。
  • listeners(event):返回指定事件的監(jiān)聽器數(shù)組。
  • emit(event, [arg1], [arg2], […]):按監(jiān)聽器的順序執(zhí)行執(zhí)行每個(gè)監(jiān)聽器,如果事件有注冊(cè)監(jiān)聽返回 true,否則返回 false。

3.2類方法

listenerCount(emitter, event):返回指定事件的監(jiān)聽器數(shù)量。

events.EventEmitter.listenerCount(emitter, eventName) //已廢棄,不推薦
events.emitter.listenerCount(eventName) //推薦

3.3 事件

  • newListener(該事件在添加新監(jiān)聽器時(shí)被觸發(fā)。)
    • event - 字符串,事件名稱
    • listener - 處理事件函數(shù)
  • removeListener(從指定監(jiān)聽器數(shù)組中刪除一個(gè)監(jiān)聽器。需要注意的是,此操作將會(huì)改變處于被刪監(jiān)聽器之后的那些監(jiān)聽器的索引。)
    • event - 字符串,事件名稱
    • listener - 處理事件函數(shù)

3.4 EventEmitter子類

大多數(shù)時(shí)候我們不會(huì)直接使用 EventEmitter,而是在對(duì)象中繼承它。包括 fs、net、 http 在內(nèi)的,只要是支持事件響應(yīng)的核心模塊都是 EventEmitter 的子類。

為什么要這樣做呢?原因有兩點(diǎn):

首先,具有某個(gè)實(shí)體功能的對(duì)象實(shí)現(xiàn)事件符合語(yǔ)義, 事件的監(jiān)聽和發(fā)生應(yīng)該是一個(gè)對(duì)象的方法。

其次 JavaScript 的對(duì)象機(jī)制是基于原型的,支持 部分多重繼承,繼承 EventEmitter 不會(huì)打亂對(duì)象原有的繼承關(guān)系。

4.舉例說明

var events = require('events');
var eventEmitter = new events.EventEmitter();
// 監(jiān)聽器 #1
var listener1 = function listener1() {
   console.log('監(jiān)聽器 listener1 執(zhí)行。');
}
// 監(jiān)聽器 #2
var listener2 = function listener2() {
  console.log('監(jiān)聽器 listener2 執(zhí)行。');
}
// 綁定 connection 事件,處理函數(shù)為 listener1 
eventEmitter.addListener('connection', listener1);
// 綁定 connection 事件,處理函數(shù)為 listener2
eventEmitter.on('connection', listener2);
var eventListeners = eventEmitter.listenerCount('connection');
console.log(eventListeners + " 個(gè)監(jiān)聽器監(jiān)聽連接事件。");
// 處理 connection 事件 
eventEmitter.emit('connection');
// 移除監(jiān)綁定的 listener1 函數(shù)
eventEmitter.removeListener('connection', listener1);
console.log("listener1 不再受監(jiān)聽。");
// 觸發(fā)連接事件
eventEmitter.emit('connection');
eventListeners = eventEmitter.listenerCount('connection');
console.log(eventListeners + " 個(gè)監(jiān)聽器監(jiān)聽連接事件。");
console.log("程序執(zhí)行完畢。");

終端執(zhí)行結(jié)果:

$ node test_event_emit.js 
2 個(gè)監(jiān)聽器監(jiān)聽連接事件。
監(jiān)聽器 listener1 執(zhí)行。
監(jiān)聽器 listener2 執(zhí)行。
listener1 不再受監(jiān)聽。
監(jiān)聽器 listener2 執(zhí)行。
1 個(gè)監(jiān)聽器監(jiān)聽連接事件。
程序執(zhí)行完畢。

到此這篇關(guān)于Node.js中的EventEmitter類介紹的文章就介紹到這了,更多相關(guān)Node.js EventEmitter類內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • nodejs中Express與Koa2對(duì)比分析

    nodejs中Express與Koa2對(duì)比分析

    提到Node.js開發(fā),不得不提目前炙手可熱的2大框架express和koa。Express誕生已有時(shí)日,是一個(gè)簡(jiǎn)潔而靈活的web開發(fā)框架,使用簡(jiǎn)單而功能強(qiáng)大。Koa相對(duì)更為年輕,是Express框架原班人馬基于ES6新特性重新開發(fā)的敏捷開發(fā)框架,現(xiàn)在可謂風(fēng)頭正勁,大有趕超Express之勢(shì)。
    2018-02-02
  • 基于 Docker 開發(fā) NodeJS 應(yīng)用

    基于 Docker 開發(fā) NodeJS 應(yīng)用

    這是兩篇文章的第一篇。本文涵蓋了有關(guān)在使用 Express 框架開發(fā)一個(gè)Node應(yīng)用時(shí),用Docker 替代 Vagrant 的比較詳細(xì)的教程, 應(yīng)用將使用 connect-redis 中間件將會(huì)話信息持久化到Redis中. 第二篇文章將介紹到將這個(gè)開發(fā)的設(shè)置產(chǎn)品化.
    2014-07-07
  • Node.js?中?fs?模塊的高級(jí)用法實(shí)例詳解

    Node.js?中?fs?模塊的高級(jí)用法實(shí)例詳解

    文章介紹了Node.js中fs模塊的高級(jí)用法,包括流式讀寫、文件監(jiān)視、PromiseAPI、遞歸目錄操作等,這些功能有助于更好地處理復(fù)雜文件操作場(chǎng)景,提升代碼性能和可維護(hù)性,感興趣的朋友跟隨小編一起看看吧
    2025-02-02
  • 理解nodejs的stream和pipe機(jī)制的原理和實(shí)現(xiàn)

    理解nodejs的stream和pipe機(jī)制的原理和實(shí)現(xiàn)

    本篇文章主要介紹了理解nodejs的stream和pipe機(jī)制的原理和實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 快速了解Node中的Stream流是什么

    快速了解Node中的Stream流是什么

    今天小編就為大家分享一篇關(guān)于快速了解Node中的Stream流是什么,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • 從零學(xué)習(xí)node.js之mysql數(shù)據(jù)庫(kù)的操作(五)

    從零學(xué)習(xí)node.js之mysql數(shù)據(jù)庫(kù)的操作(五)

    因?yàn)榻佑|Node.JS已經(jīng)有一段時(shí)間了,最近粗略的研究了一下node.js操作數(shù)據(jù)庫(kù)的包,覺得node.js連接數(shù)據(jù)庫(kù)不錯(cuò)。下面這篇文章主要給大家介紹了node.js之mysql數(shù)據(jù)庫(kù)操作的相關(guān)資料,需要的朋友可以參考下。
    2017-02-02
  • Node.js使用Express創(chuàng)建Web項(xiàng)目詳細(xì)教程

    Node.js使用Express創(chuàng)建Web項(xiàng)目詳細(xì)教程

    如果需要入門使用node.js進(jìn)行web開發(fā),正在學(xué)習(xí) nodejs web開發(fā)指南 的和想快速了解node.js web開發(fā)模式的朋友,相信本文是有一定幫助意義的。
    2017-03-03
  • Node.js基礎(chǔ)入門之模塊與npm包管理器使用詳解

    Node.js基礎(chǔ)入門之模塊與npm包管理器使用詳解

    Node.js是一個(gè)基于Chrome?V8引擎的JavaScript運(yùn)行時(shí)。類似于Java中的JRE,.Net中的CLR。本文將詳細(xì)為大家介紹Node.js中的模塊與npm包管理器的使用,需要的可以參考一下
    2022-03-03
  • 基于npm?install或run時(shí)一些報(bào)錯(cuò)的解決方案

    基于npm?install或run時(shí)一些報(bào)錯(cuò)的解決方案

    這篇文章主要介紹了基于npm?install或run時(shí)一些報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 詳解nodejs異步I/O和事件循環(huán)

    詳解nodejs異步I/O和事件循環(huán)

    本篇文章主要介紹了nodejs異步I/O和事件循環(huán),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06

最新評(píng)論