您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關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); });
上述就是小編為大家分享的Node.js中有哪些設計模式了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。