JavaScript設(shè)計模式之模板方法模式原理與用法示例
本文實例講述了JavaScript設(shè)計模式之模板方法模式原理與用法。分享給大家供大家參考,具體如下:
一、模板方法模式:一種只需使用繼承就可以實現(xiàn)的非常簡單的模式。
二、模板方法模式由兩部分組成,第一部分是抽象父類,第二部分是具體的實現(xiàn)子類。
三、以設(shè)計模式中的Coffee or Tea來說明模板方法模式:
1、模板Brverage,代碼如下:
var Beverage = function(){};
Beverage.prototype.boilWater = function(){
console.log('把水煮沸');
};
Beverage.prototype.pourInCup = function(){
throw new Error( '子類必須重寫pourInCup' );
};
Beverage.prototype.addCondiments = function(){
throw new Error( '子類必須重寫addCondiments方法' );
};
Beverage.prototype.customerWantsConditions = function(){
return true; //默認(rèn)需要調(diào)料
};
Beverage.prototype.init = function(){
this.boilWater();
this.brew();
this.pourInCup();
if(this.customerWantsCondiments()){
//如果掛鉤返回true,則需要調(diào)料
this.addCondiments();
}
};
2、子類繼承父類
var CoffeeWithHook = function(){};
CoffeeWithHook.prototype = new Beverage();
CoffeeWithHook.prototype.brew = function(){
console.log('把咖啡倒進(jìn)杯子');
};
CoffeeWithHook.prototype.addCondiments = function(){
console.log('加糖和牛奶');
};
CoffeeWithHook.prototype.customerWantsCondiments = function(){
return window.confirm( '請問需要調(diào)料嗎?' );
};
3、煮一杯咖啡
var coffeeWithHook = new CoffeeWithHook(); coffeeWithHook.init();
四、另一種寫法
var Beverage = function( param ){
var boilWater = function(){
console.log( '把水煮沸' );
};
var brew = param.brew || function(){
throw new Error( '必須傳遞brew方法' );
};
var pourInCup = param.pourInCup || function(){
throw new Error( '必須傳遞pourInCup方法' );
};
var addCondiments = param.addCondiments || function(){
throw new Error( '必須傳遞addCondiments方法' );
};
var F = function(){};
F.prototype.init = function(){
boilWater();
brew();
pourInCup();
addCondiments();
};
return F;
};
var Coffee = Beverage({
brew: function(){
console.log( '用沸水沖泡咖啡' );
},
pourInCup: function(){
console.log('把咖啡倒進(jìn)杯子');
},
addCondiments: function(){
console.log('加糖和牛奶');
}
});
var coffee = new Coffee();
coffee.init();
上述代碼使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試運行結(jié)果:

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
- 學(xué)習(xí)JavaScript設(shè)計模式之模板方法模式
- javascript設(shè)計模式 – 觀察者模式原理與用法實例分析
- javascript設(shè)計模式 – 狀態(tài)模式原理與用法實例分析
- javascript設(shè)計模式 – 策略模式原理與用法實例分析
- javascript設(shè)計模式 – 備忘錄模式原理與用法實例分析
- javascript設(shè)計模式 – 中介者模式原理與用法實例分析
- javascript設(shè)計模式 – 命令模式原理與用法實例分析
- javascript設(shè)計模式 – 解釋器模式原理與用法實例分析
- javascript設(shè)計模式 – 迭代器模式原理與用法實例分析
- javascript設(shè)計模式 – 裝飾模式原理與應(yīng)用實例分析
- javascript設(shè)計模式 – 組合模式原理與應(yīng)用實例分析
- javascript設(shè)計模式 – 模板方法模式原理與用法實例分析
相關(guān)文章
javaScript中定義類或?qū)ο蟮奈宸N方式總結(jié)
下面小編就為大家?guī)硪黄猨avaScript中定義類或?qū)ο蟮奈宸N方式總結(jié)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12
js定時調(diào)用方法成功后并停止調(diào)用示例
這篇文章主要介紹了js定時調(diào)用方法成功后并停止調(diào)用的實現(xiàn),需要的朋友可以參考下2014-04-04
理清apply(),call()的區(qū)別和關(guān)系
如果沒接觸過動態(tài)語言,以編譯型語言的思維方式去理解javaScript將會有種神奇而怪異的感覺,因為意識上往往不可能的事偏偏就發(fā)生了,甚至覺得不可理喻.2011-08-08
JavaScript高級程序設(shè)計 閱讀筆記(二十一) JavaScript中的XML
雖然XML和DOM已經(jīng)變成Web開發(fā)的重要組成部分,但目前僅IE跟Mozilla支持客戶端的XML處理2012-09-09
JavaScript中alert的使用方法超詳細(xì)介紹
JS中的alert作用是在瀏覽器中彈出一個警告框,而使用alert有三種方式,不同的方式所呈現(xiàn)的效果也不相同,這篇文章主要給大家介紹了關(guān)于JavaScript中alert使用方法的相關(guān)資料,需要的朋友可以參考下2024-01-01

