Node.js中的通用基礎設計模式

jopen 9年前發布 | 11K 次閱讀 Node.js Node.js 開發
 

談到設計模式,你可能會想到 singletons, observers(觀察者) 或 factories(工廠方法)。本文不并專門探討他們。只是探討Node.JS一些基礎模式的實現,像依賴注入或中間件。

什么是設計模式?

設計模式是用來解決一般的,普遍發生的問題,且可重復使用的解決方案。

Singletons (單例)

Singletons模式限制了“類”,只有一個實例。在Node.js的創建單例是非常簡單的,比如下面這個require。

//area.js

var PI = Math.PI;

function circle (radius) {  

return radius * radius * PI;

}

module.exports.circle = circle;  

你引用多少次都沒有關系;它將只存在一個單一的實例。

var areaCalc = require('./area');

console.log(areaCalc.circle(5));  

由于 require 的這種實現,單例可能在NPM模塊中最常見的Node.js設計模式。

Observers(觀察者)

一個維護了偵聽/觀察列表的對象,當狀態改變時會自動通知他們。為了實現觀察者模式,EventEmitter就派上用場了。

// MyFancyObservable.js

var util = require('util');  

var EventEmitter = require('events').EventEmitter;

function MyFancyObservable() {  

EventEmitter.call(this);

}

util.inherits(MyFancyObservable, EventEmitter);  

就是這個;我們實現了一個可觀察的對象!為了用它,讓我們添加一些方法吧。

MyFancyObservable.prototype.hello = function (name) {  

this.emit('hello', name);

};

太好了,試試偵聽并響應這個事件!

var MyFancyObservable = require('MyFancyObservable');  

var observable = new MyFancyObservable();

observable.on('hello', function (name) {  

console.log(name);

});

observable.hello('john');  

Factories (工廠方法)

工廠模式是一種創建者模式,不需要我們使用構造函數,它提供用于創建對象的通用接口。這種模式可以用于生成創建過程非常復雜的對象。

function MyClass (options) {  

this.options = options;

}

function create(options) {  

// modify the options here if you want

return new MyClass(options);

}

module.exports.create = create;  

工廠可以讓測試更簡單,因為你可以在里面注入依賴關系。

Dependency Injection 依賴注入

依賴注入是將其中的一個或多個依賴(或服務)注入,或通過引用傳遞到從屬對象的設計模式。

在這個例子中,我們將創建一個的usermodel它獲取數據庫的依賴。

function userModel (options) {  

var db;

if (!options.db) {

throw new Error('Options.db is required');

}

db = options.db;

return {

create: function (done) {

db.query('INSERT ...', done);

}

}

}

module.exports = userModel;  

現在,我們利用它創建一個實例:

var db = require('./db');

var userModel = require('User')({  

db: db

});

它為什么有用呢?它使測試變得更容易 - 當你寫單元測試時,你可以把假的數據庫實例注入模型。

Middlewares/pipelines 中間件/管道

中間件是一個強大功能且簡單的概念:一個功能單元的輸出是下一個功能單元的輸入。如果你用過Express那么你已經使用了這個模式。

我們看一看 Koa 是如何做的:

app.use = function(fn){  

this.middleware.push(fn);

return this;

};

所以基本上,當你添加一個中間件時,它只是被壓入一個中間件隊列中。但是當一個請求到達這個服務器會發生什么?

var i = middleware.length;  

while (i--) {  

next = middleware[i].call(this, next);

}

沒什么神奇的 - 你的中間件被一個接著一個調用了。

Streams

你可以把流作為特殊的管道。他比較適合處理大量數據流,即他們是字節,而不是對象。

process.stdin.on('readable', function () {  

var buf = process.stdin.read(3);

console.dir(buf);

process.stdin.read(0);

});

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!