站長資訊網
最全最豐富的資訊網站

聊聊Node.js中的事件驅動程序和EventEmitter類

本篇文章帶大家了解一下Node中的事件,聊聊一下事件驅動程序和EventEmitter 類,希望對大家有所幫助!

聊聊Node.js中的事件驅動程序和EventEmitter類

Nodejs 是單進程單線程應用程序,但是因為 V8 引擎提供的異步執行回調接口,通過這些接口可以處理大量的并發,所以性能非常高。

Node.js 幾乎每一個 API 都是支持回調函數的。

Node.js 基本上所有的事件機制都是用設計模式中觀察者模式實現。

Node.js 單線程類似進入一個while(true)的事件循環,直到沒有事件觀察者退出,每個異步事件都生成一個事件觀察者,如果有事件發生就調用該回調函數。


事件驅動程序

Node.js 使用事件驅動模型,當web server接收到請求,就把它關閉然后進行處理,然后去服務下一個web請求。

當這個請求完成,它被放回處理隊列,當到達隊列開頭,這個結果被返回給用戶。

這個模型非常高效可擴展性非常強,因為 webserver 一直接受請求而不等待任何讀寫操作。(這也稱之為非阻塞式IO或者事件驅動IO)

在事件驅動模型中,會生成一個主循環來監聽事件,當檢測到事件時觸發回調函數。

Node.js 有多個內置的事件,我們可以通過引入 events 模塊,并通過實例化 EventEmitter 類來綁定和監聽事件,如下實例:

// 引入 events 模塊 var events = require('events'); // 創建 eventEmitter 對象 var eventEmitter = new events.EventEmitter();

以下程序綁定事件處理程序:

// 綁定事件及事件的處理程序 eventEmitter.on('eventName', eventHandler);

我們可以通過程序觸發事件:

// 觸發事件 eventEmitter.emit('eventName');

實例

創建 index.js 文件,代碼如下所示:

//引入 fs 模塊 var fs = require("fs");  // 引入 events 模塊 var events = require('events');  // 創建對象 var ee = new events.EventEmitter();  // 綁定事件及事件的處理程序 ee.on('res', function (data) {     console.log('res-1');     console.log(data); }); ee.on('res', function () {     console.log('res-2'); });  fs.readFile('hello.txt',{flag:'r',encoding:'utf-8'},function(err,data){     if(err){         console.log("讀取出錯:"+err);     }else{         console.log("讀取成功:"+data);         // 觸發res事件         ee.emit('res',data);     } })

接下來讓我們執行以上代碼:

聊聊Node.js中的事件驅動程序和EventEmitter類

EventEmitter 類

events 模塊只提供了一個對象: events.EventEmitterEventEmitter 的核心就是事件觸發與事件監聽器功能的封裝。

你可以通過require("events");來訪問該模塊。

// 引入 events 模塊 var events = require('events'); // 創建 eventEmitter 對象 var eventEmitter = new events.EventEmitter();

EventEmitter 對象如果在實例化時發生錯誤,會觸發 error 事件。當添加新的監聽器時,newListener 事件會觸發,當監聽器被移除時,removeListener 事件被觸發。

下面我們用一個簡單的例子說明 EventEmitter 的用法:

//event.js 文件 var EventEmitter = require('events').EventEmitter;  var event = new EventEmitter();  event.on('some_event', function() {      console.log('some_event 事件觸發');  });  setTimeout(function() {      event.emit('some_event');  }, 1000);

執行結果如下:

運行這段代碼,1 秒后控制臺輸出了 'some_event 事件觸發' 。其原理是 event 對象注冊了事件 some_event 的一個監聽器,然后我們通過 setTimeout 在 1000 毫秒以后向 event 對象發送事件 some_event,此時會調用some_event 的監聽器。

$ node event.js  some_event 事件觸發

EventEmitter 的每個事件由一個事件名和若干個參數組成,事件名是一個字符串,通常表達一定的語義。對于每個事件,EventEmitter 支持 若干個事件監聽器。

當事件觸發時,注冊到這個事件的事件監聽器被依次調用,事件參數作為回調函數參數傳遞。

讓我們以下面的例子解釋這個過程:

//event.js 文件 var events = require('events');  var emitter = new events.EventEmitter();  emitter.on('someEvent', function(arg1, arg2) {      console.log('listener1', arg1, arg2);  });  emitter.on('someEvent', function(arg1, arg2) {      console.log('listener2', arg1, arg2);  });  emitter.emit('someEvent', 'arg1 參數', 'arg2 參數');

執行以上代碼,運行的結果如下:

$ node event.js  listener1 arg1 參數 arg2 參數 listener2 arg1 參數 arg2 參數

以上例子中,emitter 為事件 someEvent 注冊了兩個事件監聽器,然后觸發了 someEvent 事件。

運行結果中可以看到兩個事件監聽器回調函數被先后調用。 這就是EventEmitter最簡單的用法。

EventEmitter 提供了多個屬性,如 onemiton 函數用于綁定事件函數,emit 屬性用于觸發一個事件。

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
成年日韩片av在线网站| 国产精品99久久免费| 国产精品亚洲二区在线观看| 精品国产一区二区三区香蕉事 | 青青青青久久精品国产h| 日韩午夜免费视频| 国产精品一卡二卡三卡四卡| 91麻豆精品国产自产在线| 99re6在线精品免费观看| 日韩美香港a一级毛片| 国产精品免费小视频| 99爱在线精品免费观看| 无码日韩精品一区二区三区免费| 三上悠亚国产精品一区| 国产伦精品一区二区三区免费下载| 国产精品久久婷婷六月丁香| 亚洲精品在线不卡| 日韩精品无码专区免费播放| 久久国产精品一国产精品| 久久91精品国产91久久小草| 综合国产精品第一页| 久久亚洲中文字幕精品一区| 国产精品爽爽ⅴa在线观看| 亚洲?V无码乱码国产精品 | 久久99精品一久久久久久| 国产精品美女久久久久久2018| 中文精品人人永久免费| 中文字幕精品视频在线| 宅男在线国产精品无码| 伊人久久精品午夜| 久久中文精品无码中文字幕| 国产麻豆精品入口在线观看| 国产精品免费久久| 国产免费久久精品丫丫| 精品人妻伦一二三区久久| 久久精品中文字幕一区| 国内精品久久久久久久coent | 无码日韩精品一区二区免费暖暖 | 久久精品国产亚洲av影院| 久久精品亚洲一区二区三区浴池| 99热精品在线免费观看|