欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

node.js如何自定義實現(xiàn)一個EventEmitter

 更新時間:2021年07月16日 15:48:47   作者:loveStarBoys  
我們了解到,Node采用了事件驅(qū)動機制,而EventEmitter就是Node實現(xiàn)事件驅(qū)動的基礎,本文主要介紹了node.js自定義實現(xiàn)EventEmitter,感興趣的可以了解一下

前言

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

一、是什么

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

二、nodejs中EventEmitter使用方法

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

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

三、實現(xiàn)過程

基本代碼如下所示:

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

        };
        EventDispatcherClosure.prototype = {
            /**
             * 注冊事件
             * @param {Object} key
             * @param {Object} fn
             */
            on: function(key, fn) {
                //獲取當前的事件對象
                var curEvents = this._getCurEvents(key);
                //先檢查該事件是否已經(jīng)注冊過了
                var flag = false;
                for (var i = 0, len = curEvents.length; i < len; i++) {
                    if (curEvents[i].name == fn.name) {
                        //已經(jīng)出現(xiàn)過了,以最新注冊的函數(shù)為主
                        flag = true;
                        curEvents[i] = fn;
                        break;
                    }
                }
                if (!flag) {
                    curEvents[curEvents.length] = fn;
                }
                this._register(key, curEvents);
            },
            /**
             * 派發(fā)事件
             * @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 {
                        //獲取參數(shù)
                        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];
                }
            },
            /**
             * 根據(jù)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();
})();

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

事件分發(fā)的調(diào)用

EventDispatcher.dispatch("test", obj)

事件監(jiān)聽

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

事件刪除

EventDispatcher.on("test")

代碼封裝的比較簡單

到此這篇關于node.js如何自定義實現(xiàn)一個EventEmitter的文章就介紹到這了,更多相關node實現(xiàn)EventEmitter內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • node.js博客項目開發(fā)手記

    node.js博客項目開發(fā)手記

    本篇文章給大家總結(jié)了node.js博客項目開發(fā)的相關步驟以及知識點分享,有興趣的朋友參考下。
    2018-03-03
  • Node.js設置CORS跨域請求中多域名白名單的方法

    Node.js設置CORS跨域請求中多域名白名單的方法

    這篇文章主要介紹了Node.js設置CORS跨域請求中多域名白名單的方法,文中通過示例代碼介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • nodejs制作爬蟲實現(xiàn)批量下載圖片

    nodejs制作爬蟲實現(xiàn)批量下載圖片

    本文給大家分享的是作者使用nodejs制作爬蟲來爬去圖片并批量下載的全過程,非常的細致,有需要的小伙伴可以參考下
    2017-05-05
  • Node.js web 應用如何封裝到Docker容器中

    Node.js web 應用如何封裝到Docker容器中

    這篇文章主要介紹了Node.js web 應用如何封裝到Docker容器中,幫助大家更好的學習node.js和使用docker容器,感興趣的朋友可以了解下
    2020-09-09
  • Express框架實現(xiàn)簡單攔截器功能示例

    Express框架實現(xiàn)簡單攔截器功能示例

    這篇文章主要介紹了Express框架實現(xiàn)簡單攔截器功能,結(jié)合實例形式分析了express框架攔截器相關功能與使用方法,需要的朋友可以參考下
    2023-05-05
  • Node.js操作redis實現(xiàn)添加查詢功能

    Node.js操作redis實現(xiàn)添加查詢功能

    Redis 是一個基于內(nèi)存的鍵(key)值(value)類型的數(shù)據(jù)結(jié)構存儲容器,它既可以完全工作在內(nèi)存中,也可以持久化存儲。當 Redis 工作于持久化模式時,可以將它當作一個非關系型數(shù)據(jù)庫使用。
    2017-05-05
  • 配置nodejs環(huán)境的方法

    配置nodejs環(huán)境的方法

    本篇文章主要介紹了配置nodejs環(huán)境變量的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 詳解基于Node.js的HTTP/2 Server實踐

    詳解基于Node.js的HTTP/2 Server實踐

    HTTP/2目前已經(jīng)逐漸的在各大網(wǎng)站上開始使用,這篇文章主要介紹了詳解基于Node.js的HTTP/2 Server實踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 詳解node如何讓一個端口同時支持https與http

    詳解node如何讓一個端口同時支持https與http

    眾所周知node是一個高性能的web服務器,使用它可以很簡單的創(chuàng)建一個http或https的服務器。這篇文章主要介紹了詳解node如何讓一個端口同時支持https與http
    2017-07-07
  • 解析NodeJs的調(diào)試方法

    解析NodeJs的調(diào)試方法

    本文主要介紹了NodeJs調(diào)試的步驟,以及實例方法,具有一定的參考作用,需要的朋友可以看下
    2016-12-12

最新評論