Node.js-이벤트 이미 터

노드의 많은 객체는 이벤트를 내 보냅니다. 예를 들어 net.Server는 피어가 연결할 때마다 이벤트를 내 보냅니다. fs.readStream은 파일이 열릴 때 이벤트를 내 보냅니다. 이벤트를 발생시키는 모든 객체는 events.EventEmitter의 인스턴스입니다.

EventEmitter 클래스

이전 섹션에서 보았 듯이 EventEmitter 클래스는 이벤트 모듈에 있습니다. 다음 코드를 통해 액세스 할 수 있습니다.

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

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

EventEmitter 인스턴스가 오류에 직면하면 '오류'이벤트를 내 보냅니다. 새 리스너가 추가되면 'newListener'이벤트가 발생하고 리스너가 제거되면 'removeListener'이벤트가 발생합니다.

EventEmitter는 다음과 같은 여러 속성을 제공합니다. onemit. on 속성은 이벤트와 함수를 바인딩하는 데 사용되며 emit 이벤트를 발생시키는 데 사용됩니다.

행동 양식

Sr. 아니. 방법 및 설명
1

addListener(event, listener)

지정된 이벤트의 리스너 배열 끝에 리스너를 추가합니다. 리스너가 이미 추가되었는지 확인하지 않습니다. 이벤트와 리스너의 동일한 조합을 전달하는 여러 호출은 리스너가 여러 번 추가되는 결과를 가져옵니다. 이미 터를 반환하므로 호출을 연결할 수 있습니다.

2

on(event, listener)

지정된 이벤트의 리스너 배열 끝에 리스너를 추가합니다. 리스너가 이미 추가되었는지 확인하지 않습니다. 이벤트와 리스너의 동일한 조합을 전달하는 여러 호출은 리스너가 여러 번 추가되는 결과를 가져옵니다. 이미 터를 반환하므로 호출을 연결할 수 있습니다.

once(event, listener)

이벤트에 일회성 리스너를 추가합니다. 이 리스너는 다음에 이벤트가 시작된 후 제거 될 때만 호출됩니다. 이미 터를 반환하므로 호출을 연결할 수 있습니다.

4

removeListener(event, listener)

지정된 이벤트에 대한 리스너 배열에서 리스너를 제거합니다. Caution −리스너 뒤의 리스너 배열에서 배열 인덱스를 변경합니다. removeListener는 리스너 배열에서 리스너의 인스턴스를 최대 하나 제거합니다. 단일 리스너가 지정된 이벤트에 대한 리스너 배열에 여러 번 추가 된 경우 removeListener를 여러 번 호출하여 각 인스턴스를 제거해야합니다. 이미 터를 반환하므로 호출을 연결할 수 있습니다.

5

removeAllListeners([event])

모든 리스너 또는 지정된 이벤트의 리스너를 제거합니다. 코드의 다른 곳에 추가 된 리스너를 제거하는 것은 좋지 않습니다. 특히 생성하지 않은 이미 터 (예 : 소켓 또는 파일 스트림)에있는 경우에는 더욱 그렇습니다. 이미 터를 반환하므로 호출을 연결할 수 있습니다.

6

setMaxListeners(n)

기본적으로 EventEmitters는 특정 이벤트에 대해 10 개 이상의 리스너가 추가되면 경고를 출력합니다. 이것은 메모리 누수를 찾는 데 도움이되는 유용한 기본값입니다. 분명히 모든 이미 터가 10으로 제한되어서는 안됩니다.이 기능을 사용하면이를 늘릴 수 있습니다. 무제한의 경우 0으로 설정하십시오.

7

listeners(event)

지정된 이벤트에 대한 리스너 배열을 반환합니다.

8

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

제공된 인수를 사용하여 각 리스너를 순서대로 실행하십시오. 이벤트에 리스너가 있으면 true를 반환하고 그렇지 않으면 false를 반환합니다.

수업 방법

Sr. 아니. 방법 및 설명
1

listenerCount(emitter, event)

주어진 이벤트에 대한 리스너 수를 반환합니다.

이벤트

Sr. 아니. 이벤트 및 설명
1

newListener

  • event − 문자열 : 이벤트 이름

  • listener − 기능 : 이벤트 핸들러 기능

이 이벤트는 리스너가 추가 될 때마다 발생합니다. 이 이벤트가 트리거되면 리스너가 이벤트에 대한 리스너 배열에 아직 추가되지 않았을 수 있습니다.

2

removeListener

  • event − 문자열 이벤트 이름

  • listener − 기능 이벤트 핸들러 기능

이 이벤트는 누군가 리스너를 제거 할 때마다 발생합니다. 이 이벤트가 트리거되면 리스너가 이벤트에 대한 리스너 배열에서 아직 제거되지 않았을 수 있습니다.

다음 Node.js 코드로 main.js라는 js 파일을 만듭니다.

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.");

이제 결과를 보려면 main.js를 실행하십시오.

$ node main.js

출력을 확인하십시오.

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.