>웹 프론트엔드 >JS 튜토리얼 >Node.js 이벤트 이미터

Node.js 이벤트 이미터

DDD
DDD원래의
2024-12-12 22:16:11876검색

Node.js EventEmitter

오늘은 EventEmitter 클래스에 대해 말씀드리겠습니다. 아시다시피 Node.js에는 이벤트 중심 프로그래밍 패러다임이 있습니다. 이는 일부 이벤트와 콜백을 정의하고 이벤트가 프로그램 흐름에서 트리거되고 처리된다는 것을 의미합니다. 이런 접근 방식을 채택한 이유를 묻는다면, 이전 글에서 좀 더 자세히 설명했던 자바스크립트가 단일 스레드로 실행되고, 비동기 작업은 어떤 식으로든 차단되지 않고 처리되어야 하기 때문입니다.

이 모든 것이 EventEmitter 클래스와 무슨 관련이 있는지 묻는다면 이 클래스는 비동기 작업을 쉽게 처리할 수 있는 구조를 제공합니다. 실제로 이것은 Observer Design Pattern 구현입니다.

const EventEmitter = require("events");
class Emitter extends EventEmitter {}

const myE = new Emitter();

myE.on("test", () => {
  console.log("event meydana geldi.");
});
myE.on("test", () => {
  console.log("event meydana geldi.");
});
myE.on("test", () => {
  console.log("event meydana geldi.");
});

console.log(myE.eventNames());

myE.emit("test");

위에서 이벤트를 정의하고 호출하는 방법에 대한 간단한 예를 작성했습니다. 여기서 "on" 메소드는 실제로 빈 개체(마스터 개체)에 "test"라는 배열을 생성합니다.

{
  test: [
    [Function (anonymous)],
    [Function (anonymous)],
    [Function (anonymous)]
  ]
}

여기서는 eventName이라는 이름으로 "on" 메소드를 3번 호출하고 결과 구조는 위와 같습니다.
짐작할 수 있듯이 "test"라는 이벤트는 "emit" 메서드로 호출됩니다. 여기서 foreach 메서드는 테스트 배열을 반환하고 그 안에 있는 함수를 호출합니다.

그럼 이 구조는 어디에 사용되나요?
예를 들어 DOM 이벤트에서

const btn = document.getElementById("btn");
btn.addEventListener("click", () => {
  console.log("clicked");
});

예를 들어 Node.js 애플리케이션의 네트워크 요청에서

const http = require("http");
const req = http
  .request(
    {
      method: "GET",
      hostname: "jsonplaceholder.typicode.com",
      path: "/todos/1"
    },
    (res) => {
      res.on("data", (chunk) => {
        console.log(chunk.toString());
      });

      res.on("end", () => {
        console.log("response ended.");
      });
    }
  )
  .end();

위 내용은 Node.js 이벤트 이미터의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.