策略模式
策略模式指的是定义一些列的算法,把他们一个个封装起来,目的就是将算法的使用与算法的实现分离开来。说白了就是以前要很多判断的写法,现在把判断里面的内容抽离开来,变成一个个小的个体。
代码实现:
代码情景为超市促销,vip为5折,老客户3折,普通顾客没折,计算最后需要支付的金额。
没有使用策略模式的情况:
function Price(personType, price) { //vip 5 折 if (personType == 'vip') { return price * 0.5; } else if (personType == 'old'){ //老客户 3 折 return price * 0.3; } else { return price; //其他都全价 } }
不足之处:不好的地方,当我有其他方面的折扣时,又或者我活动的折扣时经常变化的,这样就要不断的修改if..else里面的条件了。而且也违背了设计模式的一个原则:对修改关闭,对扩展开放的原则;
使用策略模式之后:
// 对于vip客户 function vipPrice() { this.discount = 0.5; } vipPrice.prototype.getPrice = function(price) { return price * this.discount; } // 对于老客户 function oldPrice() { this.discount = 0.3; } oldPrice.prototype.getPrice = function(price) { return price * this.discount; } // 对于普通客户 function Price() { this.discount = 1; } Price.prototype.getPrice = function(price) { return price ; } // 上下文,对于客户端的使用 function Context() { this.name = ''; this.strategy = null; this.price = 0; } Context.prototype.set = function(name, strategy, price) { this.name = name; this.strategy = strategy; this.price = price; } Context.prototype.getResult = function() { console.log(this.name + ' 的结账价为: ' + this.strategy.getPrice(this.price)); } var context = new Context(); var vip = new vipPrice(); context.set ('vip客户', vip, 200); context.getResult(); // vip客户 的结账价为: 100 var old = new oldPrice(); context.set ('老客户', old, 200); context.getResult(); // 老客户 的结账价为: 60 var Price = new Price(); context.set ('普通客户', Price, 200); context.getResult(); // 普通客户 的结账价为: 200
通过策略模式,使得客户的折扣与算法解藕,又使得修改跟扩展能独立的进行,不影到客户端或其他算法的使用;
使用场景:
策略模式最实用的场合就是某个“类”中包含有大量的条件性语句,比如if...else 或者 switch。每一个条件分支都会引起该“类”的特定行为以不同的方式作出改变。以其维
护一段庞大的条件性语句,不如将每一个行为划分为多个独立的对象。每一个对象被称为一个策略。设置多个这种策略对象,可以改进我们的代码质量,也更好的进行单元测试。
模板模式
定义了一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
通俗的讲,就是将一些公共方法封装到父类,子类可以继承这个父类,并且可以在子类中重写父类的方法,从而实现自己的业务逻辑。
代码实现:
比如前端面试,基本包括笔试,技术面试,领导面试,HR面试等,但是每个公司的笔试题,技术面可能不一样,也可能一样,一样的就继承父类的方法,不一样的就重写父类的方法
var Interview = function(){}; // 笔试 Interview.prototype.writtenTest = function(){ console.log("这里是前端笔试题"); }; // 技术面试 Interview.prototype.technicalInterview = function(){ console.log("这里是技术面试"); }; // 领导面试 Interview.prototype.leader = function(){ console.log("领导面试"); }; // 领导面试 Interview.prototype.HR = function(){ console.log("HR面试"); }; // 等通知 Interview.prototype.waitNotice = function(){ console.log("等通知啊,不知道过了没有哦"); }; // 代码初始化 Interview.prototype.init = function(){ this.writtenTest(); this.technicalInterview(); this.leader(); this.HR(); this.waitNotice(); }; // 阿里巴巴的笔试和技术面不同,重写父类方法,其他继承父类方法。 var AliInterview = function(){}; AliInterview.prototype = new Interview(); // 子类重写方法 实现自己的业务逻辑 AliInterview.prototype.writtenTest = function(){ console.log("阿里的技术题就是难啊"); } AliInterview.prototype.technicalInterview = function(){ console.log("阿里的技术面就是叼啊"); } var AliInterview = new AliInterview(); AliInterview.init(); // 阿里的技术题就是难啊 // 阿里的技术面就是叼啊 // 领导面试 // HR面试 // 等通知啊,不知道过了没有哦
应用场景:
模板模式主要应用在一些代码刚开要一次性实现不变的部分。但是将来页面有修改,需要更改业务逻辑的部分或者重新添加新业务的情况。主要是通过子类来改写父类的情况,其他不需要改变的部分继承父类。
Atas ialah kandungan terperinci javascript策略模式、模板模式使用场景和实现代码详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!