node.js實(shí)現(xiàn)的裝飾者模式示例
本文實(shí)例講述了node.js實(shí)現(xiàn)的裝飾者模式。分享給大家供大家參考,具體如下:
裝飾者模式的實(shí)現(xiàn)更強(qiáng)調(diào)類(lèi)的組合而不是通過(guò)繼承。這樣可以增強(qiáng)靈活性。在node.js 中,可以通過(guò)call函數(shù)實(shí)現(xiàn)。call函數(shù)可以在一個(gè)對(duì)象中調(diào)用另一個(gè)類(lèi)的成員函數(shù),從這種意義上達(dá)成類(lèi)的組合目的。
var util = require('util');
var Beverage = function(){
var description = "Unkown Beverage"
this.getDescription = function(){
return description;
}
}
function Espresso(){
Beverage.call(this);
this.description = "Espresso";
}
util.inherits(Espresso, Beverage);
Espresso.prototype.cost = function(){
return 1.99;
}
function HouseBlend(){
Beverage.call(this);
this.description = "House Blend Coffee";
}
util.inherits(HouseBlend, Beverage);
HouseBlend.prototype.cost = function(){
return .89;
}
function Mocha(beverage){
this.beverage = beverage;
};
Mocha.prototype.getDescription = function(){
return this.beverage.getDescription() + ", Mocha";
}
Mocha.prototype.cost = function(){
return 0.20 + this.beverage.cost();
}
function Whip(beverage){
this.beverage = beverage;
};
Whip.prototype.getDescription = function(){
return this.beverage.getDescription() + ", Whip";
}
Whip.prototype.cost = function(){
return 0.40 + this.beverage.cost();
}
var beverage = new Espresso();
console.log(beverage.getDescription() + " $" + beverage.cost());
var beverage2 = new HouseBlend();
beverage2 = new Mocha(beverage2);
beverage2 = new Mocha(beverage2);
beverage2 = new Whip(beverage2);
console.log(beverage2.getDescription() + " $" + beverage2.cost());
希望本文所述對(duì)大家node.js程序設(shè)計(jì)有所幫助。
- 新手快速入門(mén)JavaScript裝飾者模式與AOP
- JavaScript設(shè)計(jì)模式之裝飾者模式實(shí)例詳解
- JavaScript設(shè)計(jì)模式之裝飾者模式定義與應(yīng)用示例
- JavaScript實(shí)現(xiàn)AOP詳解(面向切面編程,裝飾者模式)
- Javascript設(shè)計(jì)模式之裝飾者模式詳解篇
- 輕松掌握J(rèn)avaScript裝飾者模式
- 學(xué)習(xí)JavaScript設(shè)計(jì)模式之裝飾者模式
- 深入理解JavaScript系列(29):設(shè)計(jì)模式之裝飾者模式詳解
- JavaScript設(shè)計(jì)模式之裝飾者模式介紹
- javascript設(shè)計(jì)模式之裝飾者模式
相關(guān)文章
深入學(xué)習(xí)nodejs中的async模塊的使用方法
本篇文章主要介紹了nodejs中的async模塊的使用方法,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07
node實(shí)現(xiàn)mock-plugin中間件的方法
這篇文章主要介紹了node實(shí)現(xiàn)mock-plugin中間件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Pycharm配置Node.js運(yùn)行js代碼詳細(xì)過(guò)程
在PyCharm中寫(xiě)JavaScript代碼并進(jìn)行調(diào)試是非常方便的,但是有些用戶可能對(duì)如何在PyCharm中準(zhǔn)確地運(yùn)行JavaScript代碼感到困惑,這篇文章主要給大家介紹了關(guān)于Pycharm配置Node.js運(yùn)行js代碼的相關(guān)資料,需要的朋友可以參考下2023-11-11
node的EventEmitter模塊基本用法簡(jiǎn)單實(shí)現(xiàn)示例
這篇文章主要為大家介紹了node的EventEmitter模塊基本用法簡(jiǎn)單實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
node.js實(shí)現(xiàn)帶進(jìn)度條的多文件上傳
這篇文章主要為大家詳細(xì)介紹了node.js實(shí)現(xiàn)攜帶進(jìn)度條的多文件上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
vscode安裝教程以及配置node.js環(huán)境全過(guò)程
這篇文章主要給大家介紹了關(guān)于vscode安裝教程以及配置node.js環(huán)境的相關(guān)資料,VSCode是一款由微軟開(kāi)發(fā)的輕量級(jí)編輯器,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10

