今天就跟大家聊聊有關(guān)node中事件機(jī)制的原理是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
專注于為中小企業(yè)提供網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)蘇尼特左免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。Publish/Subscribe(發(fā)布/訂閱模式)
類比
要講的是一個(gè)模式,模式這個(gè)詞,聽起來就很抽象。我們先舉個(gè)栗子。假設(shè)有一家報(bào)紙機(jī)構(gòu),提供晨報(bào)、午報(bào)、晚報(bào)。如果你想要看某種報(bào)紙,你需要向報(bào)紙機(jī)構(gòu)訂閱,等對(duì)應(yīng)的報(bào)紙發(fā)布出來后,報(bào)紙機(jī)構(gòu)就會(huì)通知你來拿報(bào)紙。
在這個(gè)過程中,報(bào)紙機(jī)構(gòu)實(shí)現(xiàn)了兩個(gè)功能,一是接受客戶的訂閱;二是發(fā)布不同類型的報(bào)紙。發(fā)布報(bào)紙的時(shí)候,訂閱該類型報(bào)紙的客戶就能接收到通知。
這個(gè)報(bào)紙機(jī)構(gòu)也就是我們要實(shí)現(xiàn)的事件機(jī)制。
目的
從上面的例子可以看出:1.發(fā)布報(bào)紙;2.將報(bào)紙給到客戶;這個(gè)連續(xù)的過程由于報(bào)紙機(jī)構(gòu)的存在,變成了可以先訂閱,再發(fā)布,等到發(fā)布就自動(dòng)送到客戶手中,實(shí)現(xiàn)了動(dòng)作時(shí)間上的分離。這也是發(fā)布/訂閱系統(tǒng)的優(yōu)勢(shì)。
實(shí)現(xiàn)思路
我們有3種報(bào)紙,對(duì)應(yīng)3個(gè)事件,每個(gè)事件發(fā)生時(shí)要通知客戶。對(duì)應(yīng)的數(shù)據(jù)格式可以如下:
var Event = { morning: event1, noon: event2, night: event3 }
由于每種報(bào)紙都可能有不止一個(gè)人訂閱,那么格式可優(yōu)化成這樣:
var Event = { morning: [e11, e12,...], noon: [e21, e22], night: event3 }
當(dāng)用戶訂閱的時(shí)候,我們就將其事件添加對(duì)應(yīng)的數(shù)組中;當(dāng)事件發(fā)布的時(shí)候,就執(zhí)行相應(yīng)事件。說白了就是先存儲(chǔ)后使用。
具體代碼如下:
1.on表示訂閱,將事件添加到對(duì)應(yīng)數(shù)組中
2.emit表示發(fā)布,將對(duì)應(yīng)數(shù)組中的數(shù)據(jù)取出來執(zhí)行
3.off表示刪除無用的事件
var Event = { on: function(key, listener) { if (!this.__events) { this.__events = {} } if (!this.__events[key]) { this.__events[key] = []; } if (_indexOf(this.__events[key], listener) == -1 && typeof listener === 'function') { this.__events[key].push(listener) } }, emit: function(key) { if (!this.__events || !this.__events[key]) return //取得每次訂閱不同的參數(shù) var arg = Array.prototype.slice.call(arguments, 1) || []; var listeners = this.__events[key]; var len = listeners.length; for (var i=0; i-1) && listeners.splice(index, 1); } return this } } var _indexOf = function(array,key){ if (array === null) return -1 var i = 0, length = array.length for (; i < length; i++) if (array[i] === key) return i return -1 } //調(diào)用 Event.on('console1', function(num) { console.log(num); // 1 }); Event.emit('console1', 1)
node的EventEmitter
node的EventEmitter基本邏輯和上面提供的例子基本一樣,只是更加復(fù)雜些。
1.訂閱事件on
function _addListener(target, type, listener, prepend) { var m; var events; var existing; if (typeof listener !== 'function') throw new TypeError('"listener" argument must be a function'); events = target._events; ... if (typeof existing === 'function') { // Adding the second element, need to change to array. existing = events[type] = prepend ? [listener, existing] : [existing, listener]; } else { // If we've already got an array, just append. if (prepend) { existing.unshift(listener); } else { existing.push(listener); } } return target; } EventEmitter.prototype.addListener = function addListener(type, listener) { return _addListener(this, type, listener, false); }; EventEmitter.prototype.on = EventEmitter.prototype.addListener;
2.發(fā)布事件
EventEmitter.prototype.emit = function emit(type) { ... handler = events[type]; switch (len) { // fast cases case 1: emitNone(handler, isFn, this); break; case 2: emitOne(handler, isFn, this, arguments[1]); break; case 3: emitTwo(handler, isFn, this, arguments[1], arguments[2]); break; case 4: emitThree(handler, isFn, this, arguments[1], arguments[2], arguments[3]); break; // slower default: args = new Array(len - 1); for (i = 1; i < len; i++) args[i - 1] = arguments[i]; emitMany(handler, isFn, this, args); } }
看完上述內(nèi)容,你們對(duì)node中事件機(jī)制的原理是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。