中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-12 10:48:41 來源:腳本之家 閱讀:100 作者:咕咚蘿卜 欄目:web開發

本文實例講述了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.jb51.net/code/HtmlJsRun測試運行結果:

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

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

根河市| 通山县| 佳木斯市| 托里县| 建始县| 承德市| 慈利县| 五莲县| 庆云县| 塘沽区| 松桃| 宜川县| 当阳市| 油尖旺区| 富源县| 武夷山市| 体育| 句容市| 噶尔县| 莆田市| 突泉县| 辽阳市| 广丰县| 宜章县| 湖北省| 乐业县| 古浪县| 依安县| 德安县| 浦北县| 綦江县| 嘉峪关市| 华宁县| 江口县| 西乡县| 尼勒克县| 任丘市| 扎囊县| 唐河县| 九台市| 绥德县|