node.js實現(xiàn)的裝飾者模式示例
更新時間:2017年09月06日 10:14:51 作者:MatthewehttaM
這篇文章主要介紹了node.js實現(xiàn)的裝飾者模式,簡單說明了裝飾者模式的原理、功能并結(jié)合實例形式給出了node.js裝飾者模式的實現(xiàn)方法,需要的朋友可以參考下
本文實例講述了node.js實現(xiàn)的裝飾者模式。分享給大家供大家參考,具體如下:
裝飾者模式的實現(xiàn)更強調(diào)類的組合而不是通過繼承。這樣可以增強靈活性。在node.js 中,可以通過call函數(shù)實現(xiàn)。call函數(shù)可以在一個對象中調(diào)用另一個類的成員函數(shù),從這種意義上達成類的組合目的。
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());
希望本文所述對大家node.js程序設(shè)計有所幫助。
您可能感興趣的文章:
- 新手快速入門JavaScript裝飾者模式與AOP
- JavaScript設(shè)計模式之裝飾者模式實例詳解
- JavaScript設(shè)計模式之裝飾者模式定義與應(yīng)用示例
- JavaScript實現(xiàn)AOP詳解(面向切面編程,裝飾者模式)
- Javascript設(shè)計模式之裝飾者模式詳解篇
- 輕松掌握J(rèn)avaScript裝飾者模式
- 學(xué)習(xí)JavaScript設(shè)計模式之裝飾者模式
- 深入理解JavaScript系列(29):設(shè)計模式之裝飾者模式詳解
- JavaScript設(shè)計模式之裝飾者模式介紹
- javascript設(shè)計模式之裝飾者模式
相關(guān)文章
深入學(xué)習(xí)nodejs中的async模塊的使用方法
本篇文章主要介紹了nodejs中的async模塊的使用方法,具有一定的參考價值,有興趣的可以了解一下2017-07-07Pycharm配置Node.js運行js代碼詳細(xì)過程
在PyCharm中寫JavaScript代碼并進行調(diào)試是非常方便的,但是有些用戶可能對如何在PyCharm中準(zhǔn)確地運行JavaScript代碼感到困惑,這篇文章主要給大家介紹了關(guān)于Pycharm配置Node.js運行js代碼的相關(guān)資料,需要的朋友可以參考下2023-11-11node的EventEmitter模塊基本用法簡單實現(xiàn)示例
這篇文章主要為大家介紹了node的EventEmitter模塊基本用法簡單實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09vscode安裝教程以及配置node.js環(huán)境全過程
這篇文章主要給大家介紹了關(guān)于vscode安裝教程以及配置node.js環(huán)境的相關(guān)資料,VSCode是一款由微軟開發(fā)的輕量級編輯器,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10