node.js實(shí)現(xiàn)的裝飾者模式示例
本文實(shí)例講述了node.js實(shí)現(xiàn)的裝飾者模式。分享給大家供大家參考,具體如下:
裝飾者模式的實(shí)現(xiàn)更強(qiáng)調(diào)類的組合而不是通過繼承。這樣可以增強(qiáng)靈活性。在node.js 中,可以通過call函數(shù)實(shí)現(xiàn)。call函數(shù)可以在一個(gè)對(duì)象中調(diào)用另一個(gè)類的成員函數(shù),從這種意義上達(dá)成類的組合目的。
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ì)有所幫助。
- 新手快速入門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)文章
Node.js入門教程:在windows和Linux上安裝配置Node.js圖文教程
這篇文章主要介紹了Node.js入門教程:在windows和Linux上安裝配置Node.js的方法,本文圖文并茂,步驟明細(xì),是學(xué)習(xí)安裝node.js的絕佳教程,需要的朋友可以參考下2014-08-08
node上的redis調(diào)用優(yōu)化示例詳解
這篇文章主要給大家介紹了關(guān)于node上redis調(diào)用優(yōu)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10
如何使用docker直接運(yùn)行不同版本nodejs命令
這篇文章主要介紹了如何使用docker直接運(yùn)行不同版本nodejs命令,在不支持高版本Node.js的舊版操作系統(tǒng)上,可以通過Docker容器技術(shù)解決兼容性問題,需要的朋友可以參考下2024-10-10
Node.js+Express.js+TS實(shí)現(xiàn)簡單圖床腳本
在這篇博客文章中,我將介紹如何使用 TypeScript 和 Express 框架來編寫一個(gè)簡單的圖床腳本,可以將本地圖片上傳到服務(wù)器,并返回圖片的 URL,這樣,你就可以在 Markdown 文檔中方便地引用圖片,而不用擔(dān)心圖片的存儲(chǔ)和管理問題2023-10-10
Nodejs 和Session 原理及實(shí)戰(zhàn)技巧小結(jié)
這篇文章主要介紹了Nodejs 和Session 原理及實(shí)戰(zhàn)技巧小結(jié),需要的朋友可以參考下2017-08-08
使用Puppeteer實(shí)現(xiàn)頁面遍歷的示例代碼
很多時(shí)候我們需要遍歷我們的頁面來檢查頁面是否存在問題,以更好的保證可用性和安全性,下面就來講講如何使用puppeteer來實(shí)現(xiàn)頁面遍歷的功能吧2023-06-06
手寫Node靜態(tài)資源服務(wù)器的實(shí)現(xiàn)方法
這篇文章主要介紹了手寫Node靜態(tài)資源服務(wù)器的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03

