JavaScript设计模式之模板方法模式原理与用法示例

作者:咕咚萝卜 时间:2024-02-24 02:17:20 

本文实例讲述了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();

测试运行结果:

JavaScript设计模式之模板方法模式原理与用法示例

希望本文所述对大家JavaScript程序设计有所帮助。

来源:https://blog.csdn.net/joyksk/article/details/79853344

标签:JavaScript,设计模式,模板方法模式
0
投稿

猜你喜欢

  • Python OpenCV 使用滑动条来调整函数参数的方法

    2022-05-20 06:43:48
  • Python实现识别图片为文字的示例代码

    2022-01-02 14:57:48
  • python学习之编写查询ip程序

    2023-11-09 18:52:29
  • 一看就懂得Python的math模块

    2021-03-28 21:40:32
  • Python yield 的使用浅析

    2022-09-30 13:47:01
  • Python实现抓取城市的PM2.5浓度和排名

    2023-07-01 11:13:33
  • python函数参数(必须参数、可变参数、关键字参数)

    2023-09-17 07:54:28
  • SQL--JOIN之完全用法

    2008-09-12 17:30:00
  • Numpy 数组操作之元素添加、删除和修改的实现

    2023-06-23 22:09:03
  • Sql Server中存储过程中输入和输出参数(简单实例 一看就懂)

    2024-01-26 17:20:54
  • FrontPage XP设计教程2——网页的编辑

    2008-10-11 12:16:00
  • RSS2.0规范中文版

    2008-06-25 13:53:00
  • MYSQL教程:数据列类型与查询效率

    2009-02-27 15:37:00
  • SQL Server中链接服务器将替代远程服务器

    2009-06-15 11:03:00
  • MySQL学习笔记小结

    2024-01-26 22:20:33
  • 谈谈网页一屏有多大?

    2007-12-21 12:28:00
  • pycharm远程连接服务器调试tensorflow无法加载问题

    2023-02-14 15:03:04
  • MySQL索引优化之分页探索详细介绍

    2024-01-16 12:05:17
  • 《用户体验的要素》摘记

    2008-08-04 17:59:00
  • SQL Server中通过扩展存储过程实现数据库的远程备份与恢复

    2012-05-22 18:48:56
  • asp之家 网络编程 m.aspxhome.com