91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

node.js怎么自定義實現一個EventEmitter

發布時間:2021-07-19 16:31:41 來源:億速云 閱讀:158 作者:chen 欄目:開發技術

這篇文章主要介紹“node.js怎么自定義實現一個EventEmitter”,在日常操作中,相信很多人在node.js怎么自定義實現一個EventEmitter問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”node.js怎么自定義實現一個EventEmitter”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

目錄
  • 前言

  • 一、是什么

  • 二、nodejs中EventEmitter使用方法

  • 三、實現過程

前言

最近做了商品批發的需求,需要針對不同的商戶選擇對應的批發商品回顯到原來的界面。由于該項目的代碼是公司古董級別(這種代碼都是程序猿的痛),解決問題的時候都是小心翼翼的。為了避免這種問題減少外部依賴,手動封裝事件派發的函數。

一、是什么

我們了解到,Node采用了事件驅動機制,而EventEmitter就是Node實現事件驅動的基礎
在EventEmitter的基礎上,Node幾乎所有的模塊都繼承了這個類,這些模塊擁有了自己的事件,可以綁定/觸發監聽器,實現了異步操作
Node.js 里面的許多對象都會分發事件,比如 fs.readStream 對象會在文件被打開的時候觸發一個事件
這些產生事件的對象都是 events.EventEmitter 的實例,這些對象有一個 eventEmitter.on() 函數,用于將一個或多個函數綁定到命名事件上

二、nodejs中EventEmitter使用方法

Node的events模塊只提供了一個EventEmitter類,這個類實現了Node異步事件驅動架構的基本模式——觀察者模式
在這種模式中,被觀察者(主體)維護著一組其他對象派來(注冊)的觀察者,有新的對象對主體感興趣就注冊觀察者,不感興趣就取消訂閱,主體有更新的話就依次通知觀察者們

const EventEmitter = require('events')
class MyEmitter extends EventEmitter {}
const myEmitter = new MyEmitter()
function callback() {
    console.log('觸發了event事件!')
}
myEmitter.on('event', callback)
myEmitter.emit('event')
myEmitter.removeListener('event', callback);

三、實現過程

基本代碼如下所示:

//事件派發機制
(function() {
    var EventDispatcher = function() {
        var EventDispatcherClosure = function() {

        };
        EventDispatcherClosure.prototype = {
            /**
             * 注冊事件
             * @param {Object} key
             * @param {Object} fn
             */
            on: function(key, fn) {
                //獲取當前的事件對象
                var curEvents = this._getCurEvents(key);
                //先檢查該事件是否已經注冊過了
                var flag = false;
                for (var i = 0, len = curEvents.length; i < len; i++) {
                    if (curEvents[i].name == fn.name) {
                        //已經出現過了,以最新注冊的函數為主
                        flag = true;
                        curEvents[i] = fn;
                        break;
                    }
                }
                if (!flag) {
                    curEvents[curEvents.length] = fn;
                }
                this._register(key, curEvents);
            },
            /**
             * 派發事件
             * @param {Object} key
             * @param {Object} data
             */
            dispatch: function(key) {
                //獲取當前的事件對象
                var curEvents = this._getCurEvents(key);
                var shouldDispatch = true;
                for (var i = 0, len = curEvents.length; shouldDispatch && i < len; i++) {
                    try {
                        //獲取參數
                        var args = [];
                        for (var j = 1, len1 = arguments.length; j < len1; j++) {
                            args.push(arguments[j]);
                        }
                        shouldDispatch = curEvents[i].apply({}, args);
                    } catch (e) {
                        shouldDispatch = false;
                    }
                }
                return shouldDispatch;
            },
            remove: function(key) {
                if (this._getCurEvents(key)) {
                    delete EventDispatcherClosure.events[key];
                }
            },
            /**
             * 根據key獲取事件列表
             * @param {Object} key
             */
            _getCurEvents: function(key) {
                return EventDispatcherClosure.events[key] || [];
            },
            /**
             * 注冊時間
             * @param {Object} key
             * @param {Object} events
             */
            _register: function(key, events) {
                EventDispatcherClosure.events[key] = events;
            },
        };
        EventDispatcherClosure.events = {};
        return {
            create: function() {
                return new EventDispatcherClosure();
            }
        };
    };
    window.EventDispatcher = new EventDispatcher().create();
})();

首先定義一個全局變量的匿名函數,然后將全局變量掛在window上面,這樣可以讓我們在開發過程中的調用。在匿名函數的原型鏈上面添加事件分發、事件監聽、事件刪除等方法。

事件分發的調用

EventDispatcher.dispatch("test", obj)

事件監聽

EventDispatcher.on("test", function callback(obj) {
})

事件刪除

EventDispatcher.on("test")

代碼封裝的比較簡單

到此,關于“node.js怎么自定義實現一個EventEmitter”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

民丰县| 南皮县| 崇义县| 湟中县| 友谊县| 古交市| 正宁县| 云浮市| 南和县| 梁平县| 南陵县| 江油市| 丹东市| 神木县| 伊春市| 高青县| 都匀市| 井陉县| 德清县| 五指山市| 长春市| 东方市| 潮州市| 萨迦县| 皋兰县| 方山县| 长宁区| 曲沃县| 金塔县| 海口市| 绥阳县| 新乡市| 合肥市| 延川县| 应城市| 江西省| 隆德县| 荣昌县| 丰镇市| 南溪县| 秦皇岛市|