Node.js - Ereignisemitter

Viele Objekte in einem Knoten senden Ereignisse aus, z. B. ein net.Server gibt jedes Mal ein Ereignis aus, wenn ein Peer eine Verbindung zu ihm herstellt. Ein fs.readStream gibt ein Ereignis aus, wenn die Datei geöffnet wird. Alle Objekte, die Ereignisse ausgeben, sind Instanzen von Ereignissen. EventEmitter.

EventEmitter-Klasse

Wie wir im vorherigen Abschnitt gesehen haben, liegt die EventEmitter-Klasse im Ereignismodul. Es ist über den folgenden Code zugänglich -

// Import events module
var events = require('events');

// Create an eventEmitter object
var eventEmitter = new events.EventEmitter();

Wenn bei einer EventEmitter-Instanz ein Fehler auftritt, wird ein Fehlerereignis ausgegeben. Wenn ein neuer Listener hinzugefügt wird, wird das Ereignis 'newListener' ausgelöst, und wenn ein Listener entfernt wird, wird das Ereignis 'removeListener' ausgelöst.

EventEmitter bietet mehrere Eigenschaften wie on und emit. on Eigenschaft wird verwendet, um eine Funktion mit dem Ereignis und zu binden emit wird verwendet, um ein Ereignis auszulösen.

Methoden

Sr.Nr. Methode & Beschreibung
1

addListener(event, listener)

Fügt am Ende des Listener-Arrays einen Listener für das angegebene Ereignis hinzu. Es wird nicht geprüft, ob der Listener bereits hinzugefügt wurde. Mehrere Anrufe, die dieselbe Kombination aus Ereignis und Listener durchlaufen, führen dazu, dass der Listener mehrmals hinzugefügt wird. Gibt den Emitter zurück, sodass Anrufe verkettet werden können.

2

on(event, listener)

Fügt am Ende des Listener-Arrays einen Listener für das angegebene Ereignis hinzu. Es wird nicht geprüft, ob der Listener bereits hinzugefügt wurde. Mehrere Anrufe, die dieselbe Kombination aus Ereignis und Listener durchlaufen, führen dazu, dass der Listener mehrmals hinzugefügt wird. Gibt den Emitter zurück, sodass Anrufe verkettet werden können.

3

once(event, listener)

Fügt dem Ereignis einen einmaligen Listener hinzu. Dieser Listener wird erst beim nächsten Auslösen des Ereignisses aufgerufen und anschließend entfernt. Gibt den Emitter zurück, sodass Anrufe verkettet werden können.

4

removeListener(event, listener)

Entfernt einen Listener aus dem Listener-Array für das angegebene Ereignis. Caution −Es ändert die Array-Indizes im Listener-Array hinter dem Listener. removeListener entfernt höchstens eine Instanz eines Listeners aus dem Listener-Array. Wenn dem Listener-Array für das angegebene Ereignis ein einzelner Listener mehrmals hinzugefügt wurde, muss removeListener mehrmals aufgerufen werden, um jede Instanz zu entfernen. Gibt den Emitter zurück, sodass Anrufe verkettet werden können.

5

removeAllListeners([event])

Entfernt alle Listener oder die des angegebenen Ereignisses. Es ist keine gute Idee, Listener zu entfernen, die an anderer Stelle im Code hinzugefügt wurden, insbesondere wenn es sich um einen Emitter handelt, den Sie nicht erstellt haben (z. B. Sockets oder Dateistreams). Gibt den Emitter zurück, sodass Anrufe verkettet werden können.

6

setMaxListeners(n)

Standardmäßig druckt EventEmitters eine Warnung, wenn für ein bestimmtes Ereignis mehr als 10 Listener hinzugefügt werden. Dies ist eine nützliche Standardeinstellung, mit deren Hilfe Speicherlecks gefunden werden können. Offensichtlich sollten nicht alle Emitter auf 10 beschränkt sein. Mit dieser Funktion kann dies erhöht werden. Für unbegrenzt auf Null setzen.

7

listeners(event)

Gibt ein Array von Listenern für das angegebene Ereignis zurück.

8

emit(event, [arg1], [arg2], [...])

Führen Sie jeden Listener der Reihe nach mit den angegebenen Argumenten aus. Gibt true zurück, wenn das Ereignis Listener hatte, andernfalls false.

Klassenmethoden

Sr.Nr. Methode & Beschreibung
1

listenerCount(emitter, event)

Gibt die Anzahl der Listener für ein bestimmtes Ereignis zurück.

Veranstaltungen

Sr.Nr. Ereignisse & Beschreibung
1

newListener

  • event - String: Der Ereignisname

  • listener - Funktion: Die Ereignishandlerfunktion

Dieses Ereignis wird jedes Mal ausgegeben, wenn ein Listener hinzugefügt wird. Wenn dieses Ereignis ausgelöst wird, wurde der Listener möglicherweise noch nicht zum Listener-Array für das Ereignis hinzugefügt.

2

removeListener

  • event - String Der Ereignisname

  • listener - Funktion Die Ereignishandlerfunktion

Dieses Ereignis wird jedes Mal ausgegeben, wenn jemand einen Listener entfernt. Wenn dieses Ereignis ausgelöst wird, wurde der Listener möglicherweise noch nicht aus dem Listener-Array für das Ereignis entfernt.

Beispiel

Erstellen Sie eine js-Datei mit dem Namen main.js mit dem folgenden Node.js-Code:

var events = require('events');
var eventEmitter = new events.EventEmitter();

// listener #1
var listner1 = function listner1() {
   console.log('listner1 executed.');
}

// listener #2
var listner2 = function listner2() {
   console.log('listner2 executed.');
}

// Bind the connection event with the listner1 function
eventEmitter.addListener('connection', listner1);

// Bind the connection event with the listner2 function
eventEmitter.on('connection', listner2);

var eventListeners = require('events').EventEmitter.listenerCount
   (eventEmitter,'connection');
console.log(eventListeners + " Listner(s) listening to connection event");

// Fire the connection event 
eventEmitter.emit('connection');

// Remove the binding of listner1 function
eventEmitter.removeListener('connection', listner1);
console.log("Listner1 will not listen now.");

// Fire the connection event 
eventEmitter.emit('connection');

eventListeners = require('events').EventEmitter.listenerCount(eventEmitter,'connection');
console.log(eventListeners + " Listner(s) listening to connection event");

console.log("Program Ended.");

Führen Sie nun die Datei main.js aus, um das Ergebnis anzuzeigen.

$ node main.js

Überprüfen Sie die Ausgabe.

2 Listner(s) listening to connection event
listner1 executed.
listner2 executed.
Listner1 will not listen now.
listner2 executed.
1 Listner(s) listening to connection event
Program Ended.