本篇文章帶大家了解一下Node.js中的Events模組,介紹一下 Events 中的發布訂閱模式,希望對大家有幫助!
Events模組
#參考官網:events 事件觸發器| Node.js
http ://nodejs.cn/api/events.html
Events
模組是Node最重要的模組,它提供了一個屬性EventEmitter
,EventEmitter
的核心是事件發射與事件監聽器。
Node中大部分的模組,都繼承自 Events
模組。
-
Events
模組是Node對 發布訂閱模式(publish/subscribe
)的實作。一個物件透過這個模組,向另一個物件傳遞訊息。 - 這個模組透過
EventEmitter
屬性,提供了一個建構子。此建構函式的實例具有on
方法,可以用來監聽指定事件,並觸發回呼函數。 - 任意物件都可以發布指定事件,被
EventEmitter
實例的on方法監聽到。
發布訂閱模式
關於 發布訂閱模式 ,可以參考我之前的部落格文章。
關於 Events
中的發布訂閱模式,我們要先清楚它的幾個常用方法。
-
訂閱方法:
on
方法用來訂閱事件,訂閱是將方法對應成一種一對多的關係。 -
發布方法:
emit
用來執行訂閱的事件。 -
取消訂閱:
off
方法可以移除對應的事件監聽。 -
訂閱一次:
once
綁定事件當執行後自動刪除訂閱的事件。
on 和emit
on
方法的第一個參數用來設定類別名,第二個參數也是函數,裡面可以接收發佈時傳入的參數。
emit
方法第一個參數是類別名,之後的參數都是傳入 on
方法函數中的參數。
on
和 emit
具體應用可以參考下面這個簡單的Demo。
const EventEmitter = require('events'); // 自定义一个 构造函数 function Cat() {} // 原型继承 需要通过实例来调用继承方法 Object.setPrototypeOf(Cat.prototype, EventEmitter.prototype); let cat = new Cat(); const sleep = (a, b) => { console.log(a, '睡'); }; const eat = (a, b) => { console.log(b, '吃'); }; cat.on('猫咪', sleep) cat.on('猫咪', eat) setTimeout(() => { // 小胡子 吃 // 小胖仙 睡 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
現在我們可以實作一套 on
和 emit
方法。
function EventEmitter() { this._event = {} } // on 方法 EventEmitter.prototype.on = function (eventName, callBack) { if (!this._event) { this._event = {} } if (this._event[eventName]) { this._event[eventName].push(callBack) // 相当于 {eventName:[fn1,fn2]} } else { this._event[eventName] = [callBack]; // 相当于 {eventName:[fn1]} } } // emit 方法 EventEmitter.prototype.emit = function (eventName, ...args) { this._event[eventName].forEach(fn => { fn(...args) }); }
off
off
方法的第一個參數用來設定類別名,第二個參數傳入需要移除的函數回調。
// ... setTimeout(() => { // 小胡子 吃 // 小胖仙 睡 cat.emit('猫咪', '小胖仙', '小胡子') cat.off('猫咪', sleep); // 小胡子 吃 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
這樣我們可以大概判斷出來,移除掉和我們傳入函數相同的函數,我們很快想到 filter 方法。
// off 方法 EventEmitter.prototype.off = function (eventName, callBack) { if (this._event && this._event[eventName]) { this._event[eventName] = this._event[eventName].filter( fn => fn !== callBack && fn.c !== callBack // fn.c参考下面的once方法实现 ) } }
once
once
方法的第一個參數用來設定類別名,第二個參數傳入只需要執行一次的函數回調。
// ... const demolition =() => { console.log('拆家'); } cat.once('猫咪', demolition) setTimeout(() => { // ...... 拆家 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
這樣我們可以根據先前實作的 on
和 off
來實作此方法。
// once 方法 EventEmitter.prototype.once = function (eventName, callBack) { const one = () => { callBack(); this.off(eventName, one); } this.on(eventName, one); }
看起來這個方法好像沒有什麼問題,執行起來也全都是正確的。
但是在一種特殊情況下的時候,還是出現了錯誤。
那種情況就是如果我們在執行 once
方法之前,就已經透過 off
方法將其移除了。
我們實作的方法就無法實作這個需求了,所以我們還需要對once
方法進行一些修改( off
方法已經處理過了) 。
新增一個自訂屬性,用來對函數進行 「快取」 。
EventEmitter.prototype.once = function (eventName, callBack) { const one = () => { // ... } one.c = callBack; // 自定义一个属性 // ... }
這樣我們就實作了 once
方法。
更多node相關知識,請造訪:nodejs 教學! !
以上是Node.js學習之聊Events模組的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

本篇文章带大家详解package.json和package-lock.json文件,希望对大家有所帮助!

如何用pkg打包nodejs可执行文件?下面本篇文章给大家介绍一下使用pkg将Node.js项目打包为可执行文件的方法,希望对大家有所帮助!

本篇文章给大家分享一个Nodejs web框架:Fastify,简单介绍一下Fastify支持的特性、Fastify支持的插件以及Fastify的使用方法,希望对大家有所帮助!

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

本篇文章给大家分享一个Node实战,介绍一下使用Node.js和adb怎么开发一个手机备份小工具,希望对大家有所帮助!

先介绍node.js的安装,再介绍使用node.js构建一个简单的web服务器,最后通过一个简单的示例,演示网页与服务器之间的数据交互的实现。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

禪工作室 13.0.1
強大的PHP整合開發環境