国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript設計模式之模板方法模式原理與用法示例

2019-11-19 13:19:57
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript設計模式之模板方法模式原理與用法。分享給大家供大家參考,具體如下:

一、模板方法模式:一種只需使用繼承就可以實現的非常簡單的模式。

二、模板方法模式由兩部分組成,第一部分是抽象父類,第二部分是具體的實現子類。

三、以設計模式中的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; //默認需要調料};Beverage.prototype.init = function(){  this.boilWater();  this.brew();  this.pourInCup();  if(this.customerWantsCondiments()){    //如果掛鉤返回true,則需要調料    this.addCondiments();  }};

2、子類繼承父類

var CoffeeWithHook = function(){};CoffeeWithHook.prototype = new Beverage();CoffeeWithHook.prototype.brew = function(){  console.log('把咖啡倒進杯子');};CoffeeWithHook.prototype.addCondiments = function(){  console.log('加糖和牛奶');};CoffeeWithHook.prototype.customerWantsCondiments = function(){ return window.confirm( '請問需要調料嗎?' );};

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('把咖啡倒進杯子');  },  addCondiments: function(){    console.log('加糖和牛奶');  }});var coffee = new Coffee();coffee.init();

上述代碼使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun測試運行結果:

更多關于JavaScript相關內容可查看本站專題:《javascript面向對象入門教程》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘阴县| 吉水县| 行唐县| 鹤岗市| 华阴市| 依安县| 嘉祥县| 米脂县| 探索| 姜堰市| 石河子市| 大埔区| 贵阳市| 大丰市| 蒙阴县| 府谷县| 武安市| 潜山县| 樟树市| 保靖县| 惠来县| 察雅县| 焉耆| 西乌珠穆沁旗| 洪洞县| 乌海市| 瑞安市| 盐池县| 曲水县| 正镶白旗| 双辽市| 罗平县| 焦作市| 广河县| 八宿县| 图木舒克市| 商河县| 兰考县| 岳阳市| 衡阳县| 乌兰察布市|