code设计模式-模板方法模式

本文介绍了一种简单的设计模式——模板方法模式,通过一个具体的CoffeeorTea实例详细展示了该模式的实现过程。模板方法模式利用继承特性,在抽象父类中定义了一个算法骨架,并将某些步骤延迟到子类实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.描述:模板方法模式是一种只需要使用继承就可以实现的非常简单的模式,模式由两部分组成-抽象父类和具现子类。通常在抽象父类中封装了子类的算法框架。

2.实例:Coffee or Tea

父类-饮料-步骤:

  1. 把水煮沸
  2. 用沸水冲泡饮料
  3. 把饮料倒进杯子
  4. 加调料
var Beverage = function(){};
Beverage.prototype.boilWater = function(){
	console.log('把水煮沸');
}

Beverage.prototype.brew = function(){
	throw new Error('子类必须重写brew方法');
}

Beverage.prototype.pourInCup = function(){
	throw new Error('子类必须重写pourInCup方法');
}

Beverage.prototype.addCondiments = function(){
	throw new Error('子类必须重写addCondiments方法');
}

Beverage.prototype.ifWantsCondiments = function(){//钩子方法
	return true;//是否加调料
}

Beverage.prototype.init = function(){
	this.boilWater();
	this.brew();
	this.pourInCup();
	if(this.ifWantsCondiments()){
		this.addCondiments();
	}
}

//子类coffee
var CoffeeWithHook = function(){};
CoffeeWithHook.prototype = new Beverage();
CoffeeWithHook.prototype.brew = function(){
	console.log('用沸水冲泡咖啡');
};
CoffeeWithHook.prototype.pourInCup = function(){
	console.log('把咖啡倒进杯子');
};
CoffeeWithHook.prototype.addCondiments= function(){
	console.log('加糖和牛奶');
};
CoffeeWithHook.prototype.ifWantsCondiments= function(){
	return window.confirm('请问需要加调料吗?');
};

//泡一杯咖啡
var coffee = new CoffeeWithHook();
coffee.init();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wl_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值