亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2018年08月07日 09:35:08   作者:咕咚蘿卜  
這篇文章主要介紹了JavaScript設計模式之模板方法模式原理與用法,結合實例形式分析了JavaScript模板方法模式的概念、組成、定義、使用等相關操作技巧與注意事項,需要的朋友可以參考下

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

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

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

三、以設計模式中的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數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數(shù)學運算用法總結

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

相關文章

  • JavaScript實現(xiàn)獲取網絡通信進度

    JavaScript實現(xiàn)獲取網絡通信進度

    這篇文章主要為大家詳細介紹了如何使用Fetch?API和XMLHttpRequest(XHR)來執(zhí)行網絡請求,并重點說明如何獲取這兩種方法的網絡請求進度,感興趣的可以了解下
    2023-12-12
  • js將滾動條滾動到指定位置的簡單實現(xiàn)方法

    js將滾動條滾動到指定位置的簡單實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s將滾動條滾動到指定位置的簡單實現(xiàn)方法。小編覺得挺不錯的, 現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 微信小程序自定義yPicker組件實現(xiàn)省市區(qū)三級聯(lián)動功能

    微信小程序自定義yPicker組件實現(xiàn)省市區(qū)三級聯(lián)動功能

    這篇文章主要介紹了微信小程序自定義yPicker組件分析及省市區(qū)三級聯(lián)動實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • 純js+css實現(xiàn)在線時鐘

    純js+css實現(xiàn)在線時鐘

    這篇文章主要為大家詳細介紹了純js+css實現(xiàn)在線時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 小程序rich-text組件如何改變內部img圖片樣式的方法

    小程序rich-text組件如何改變內部img圖片樣式的方法

    這篇文章主要介紹了小程序rich-text組件如何改變內部img圖片樣式的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 小程序實現(xiàn)分類頁

    小程序實現(xiàn)分類頁

    這篇文章主要為大家詳細介紹了小程序實現(xiàn)好看的分類頁,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • JavaScript實現(xiàn)京東秒殺效果

    JavaScript實現(xiàn)京東秒殺效果

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)京東秒殺效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • layui按條件隱藏表格列的實例

    layui按條件隱藏表格列的實例

    今天小編就為大家分享一篇layui按條件隱藏表格列的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • layui的面包屑或者表單不顯示的解決方法

    layui的面包屑或者表單不顯示的解決方法

    今天小編就為大家分享一篇layui的面包屑或者表單不顯示的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 一篇文章搞懂JavaScript中的代理和代理的使用

    一篇文章搞懂JavaScript中的代理和代理的使用

    這篇文章主要為大家詳細介紹了JavaScript代理和代理的使用的方法,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-08-08

最新評論