Node.js的高效性部分源於其基於事件的架構。與每次請求都讀取所有必要文件(如PHP)不同,Node.js只需啟動服務器,初始化大部分變量,聲明函數,然後等待事件發生。雖然Node.js內置了一些有用的事件,例如request
事件,但能夠創建和触發自定義事件豈不是更有用?本文將探討如何實現這一點。首先,我們將演示如何發出普通事件。例如,當有人進入商店時,鈴鐺會響以提示其存在,這類似於觀察者模式,其中事件充當主題,所有附加到事件的函數都像觀察者。商店示例如下:
const events = require('events'); const eventEmitter = new events.EventEmitter(); const ringBell = () => { console.log('ring ring ring'); }; eventEmitter.on('doorOpen', ringBell); eventEmitter.emit('doorOpen');
首先,我們加載Node.js核心模塊events
。然後,創建一個EventEmitter
類的實例(稍後我們將擴展它)。之後,我們將ringBell
函數放入一個變量中,以便以這種方式調用它。它只是在控制台中打印“ring ring ring”。接下來是重點。我們使用eventEmitter.on()
方法將ringBell
函數添加到doorOpen
事件的函數列表中,第一個參數是事件名,第二個參數是要添加的函數。這實際上什麼也沒做,只是註冊了我們的函數。真正的魔力發生在下一行,當我們發出事件時。調用emit()
方法將執行使用on
方法註冊的所有函數。這並不那麼有趣,如果我們只想讓鈴鐺響,可以直接調用該函數。但這就是事件的有趣之處:您可以註冊任意數量的函數。例如,我們還可以這樣做:
eventEmitter.on('doorOpen', ringBell); eventEmitter.on('doorOpen', doSomething); eventEmitter.on('doorOpen', doSomethingElse); eventEmitter.emit('doorOpen');
這同樣有效,並且更充分地利用了EventEmitter
提供的功能。我們還可以使用帶有參數的函數作為監聽器:
eventEmitter.on('doorOpen', (ring) => { console.log(ring); }); eventEmitter.emit('doorOpen', 'ringeling');
我們只需在emit()
方法中傳遞參數即可。雖然這非常強大,但在Node.js社區中,一種常見的做法是從EventEmitter
類繼承。我們可以通過創建一個Door
類來實現,該類具有一個open()
方法,該方法將發出doorOpen
事件。請看這段代碼:
const events = require('events'); function Door(colour) { this.colour = colour; events.EventEmitter.call(this); this.open = () => { this.emit('open'); }; } Door.prototype.__proto__ = events.EventEmitter.prototype; const frontDoor = new Door('brown'); frontDoor.on('open', () => { console.log('ring ring ring'); }); frontDoor.open();
在我們的Door
對象的構造函數中,我們設置門顏色,並使用EventEmitter
對象的call()
方法執行EventEmitter
的構造函數方法。然後,我們聲明open
方法,該方法發出“open”事件。這行代碼:
const events = require('events'); const eventEmitter = new events.EventEmitter(); const ringBell = () => { console.log('ring ring ring'); }; eventEmitter.on('doorOpen', ringBell); eventEmitter.emit('doorOpen');
將所有EventEmitter
屬性複製到Door
對象。然後,我們創建frontDoor
,它是Door
的一個實例,顏色為棕色。然後,我們添加一個事件監聽器,最後打開門,並在控制台中打印一條消息。我希望大家都能看到這個events
模塊非常強大且有用!最後,events
模塊為我們提供了一種列出附加到事件的所有事件監聽器以及刪除事件監聽器的方法。
eventEmitter.on('doorOpen', ringBell); eventEmitter.on('doorOpen', doSomething); eventEmitter.on('doorOpen', doSomethingElse); eventEmitter.emit('doorOpen');
您可以使用listeners
屬性來實現。當然,這僅在您沒有使用匿名函數作為事件監聽器時才有效。如果我們想的話,可以從門上移除鈴鐺:
eventEmitter.on('doorOpen', (ring) => { console.log(ring); }); eventEmitter.emit('doorOpen', 'ringeling');
或者,我們甚至可以移除所有監聽器:
const events = require('events'); function Door(colour) { this.colour = colour; events.EventEmitter.call(this); this.open = () => { this.emit('open'); }; } Door.prototype.__proto__ = events.EventEmitter.prototype; const frontDoor = new Door('brown'); frontDoor.on('open', () => { console.log('ring ring ring'); }); frontDoor.open();
感謝您閱讀本指南,希望您有所收穫!下次再見!
EventEmitter
類是Node.js中的核心模塊,用於促進對象之間的通信。它是events
模塊的一部分,用於發出和處理自定義事件。 EventEmitter
類通過將函數或事件處理程序註冊到命名事件來工作。當EventEmitter
對象發出事件時,附加到該事件的所有函數都會同步調用。
創建EventEmitter
的實例很簡單。首先,您需要導入events
模塊。然後,您可以使用new
關鍵字創建一個新實例。這是一個簡單的示例:
Door.prototype.__proto__ = events.EventEmitter.prototype;
要發出事件,您可以使用EventEmitter
實例的emit
方法。此方法允許您指定事件名稱並將任意數量的參數傳遞給事件監聽器。這是一個示例:
const ring = () => { console.log('ring'); }; frontDoor.on('open', ring); console.log(require('util').inspect(frontDoor.listeners('open'))); // 输出 [ ring ]
要監聽事件,您可以使用EventEmitter
實例的on
方法。此方法允許您指定事件名稱和一個回調函數,該函數將在發出事件時被調用。這是一個示例:
frontDoor.removeListener('open', ring);
on
方法允許您添加一個回調函數,該函數將在每次發出事件時被調用。另一方面,once
方法允許您添加一個回調函數,該函數只會在第一次發出事件時被調用。
要移除事件監聽器,您可以使用EventEmitter
實例的removeListener
或off
方法。此方法允許您指定事件名稱和應移除的回調函數。這是一個示例:
const events = require('events'); const eventEmitter = new events.EventEmitter(); const ringBell = () => { console.log('ring ring ring'); }; eventEmitter.on('doorOpen', ringBell); eventEmitter.emit('doorOpen');
是的,您可以使用EventEmitter
實例的setMaxListeners
方法來限制事件的監聽器數量。此方法允許您指定可以為事件添加的最大監聽器數量。
要獲取事件的監聽器數量,您可以使用EventEmitter
實例的listenerCount
方法。此方法允許您指定事件名稱並返回該事件的監聽器數量。
是的,您可以在EventEmitter
中發出和處理錯誤。如果EventEmitter
至少沒有為error
事件註冊一個監聽器,並且發出了error
事件,則會拋出錯誤,打印堆棧跟踪,並且Node.js進程將退出。
雖然EventEmitter
是Node.js模塊,主要用於服務器端應用程序,但也有可用的瀏覽器版本。這些可以像Node.js版本一樣使用,允許您在客戶端代碼中使用相同的事件驅動架構。
以上是Node.js事件和EventEmitter的詳細內容。更多資訊請關注PHP中文網其他相關文章!