JavaScript设计模式之策略模式详解


Posted in Javascript onJune 09, 2017

在程序设计中,我们也常常遇到这种情况,要实现某一个功能我们有很多种算法可以实现。

这些算法灵活多样,而且可以随意互相替换。这种解决方案就是所谓的策略模式。

策略模式的定义是:定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。

/*
 * pre:策略模式
 * 示例:公司计算奖金,分A、B、C 三种绩效,计算方式如下
 * 绩效为A,奖金乘以系数5
 * 绩效为B,奖金乘以系数4
 * 绩效为C,奖金乘以系数3
 */
//-------- 示例1 ----------
var calculateBonus = function(performanceLevel, salary) {
 if(performanceLevel === 'A') {
  return salary * 5;
 }
 if(performanceLevel === 'B') {
  return salary * 4;
 }
 if(performanceLevel === 'C') {
  return salary * 3;
 }
};
console.log(calculateBonus('A', 2000));
/*
 缺点:1、函数体系庞大,拥有太多的if-else语句;
  2、如果增加绩效D,需修改内部函数,违背封闭-开放原则;
  3、复用性差,其他地方如果用到计算奖金,只能赋值黏贴;
 */
//--------- 示例2 ------------
var performanceA = function(salary) {
 return salary * 5;
};
var performanceB = function(salary) {
 return salary * 4;
};
var performanceC = function(salary) {
 return salary * 3;
};
var calculateBonus = function(performanceLevel, salary) {
 if(performanceLevel === 'A') {
  return performanceA(salary);
 }
 if(performanceLevel === 'B') {
  return performanceB(salary);
 }
 if(performanceLevel === 'C') {
  return performanceC(salary);
 }
};
console.log(calculateBonus('A', 2000)); 
/*
 缺点:1、函数体系庞大,系统变化时缺乏弹性
 */
//--------- 示例3 ------------
// 策略模式重构:定义一系列算法,将它们一个个封装起来。
var performanceA = function(){};
performanceA.prototype.caculate = function(salary){
 return salary * 5;
};
var performanceB = function(){};
performanceB.prototype.caculate = function(salary){
 return salary * 4;
};
var performanceC = function(){};
performanceC.prototype.caculate = function(salary){
 return salary * 3;
};

var Bonus = function(){
 this.salary = null;
 this.strategy = null;
};
Bonus.prototype.setSalary = function(salary){
 this.salary = salary;
};
Bonus.prototype.setStrategy = function(strategy){
 this.strategy = strategy;
}
Bonus.prototype.getBonus = function(){
 return this.strategy.caculate(this.salary);
}

var bonus = new Bonus();
bonus.setSalary(2000);
bonus.setStrategy(new performanceA());
console.log(bonus.getBonus());

// ----------- 示例4 ---------------
// javaScript版本
var Strategies = {
 "A":function(salary){
  return salary * 5;
 },
 "B":function(salary){
  return salary * 4;
 },
 "C":function(salary){
  return salary * 3;
 } 
};
var caculateBonus = function(level,salary){
 return Strategies[level](salary);
};
console.log(caculateBonus("A",2000));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现yield的方法
Nov 06 Javascript
Javascript setInterval的两种调用方法(实例讲解)
Nov 29 Javascript
JQuery实现鼠标移动到图片上显示边框效果
Jan 09 Javascript
JS+CSS实现可拖拽的漂亮圆角特效弹出层完整实例
Feb 13 Javascript
原生js实现tab选项卡切换
Mar 23 Javascript
jQuery实现圣诞节礼物传送(花式轮播)
Dec 25 Javascript
js模糊查询实例分享
Dec 26 Javascript
一个简易的js图片轮播效果
Jul 22 Javascript
详解微信小程序canvas圆角矩形的绘制的方法
Aug 22 Javascript
从组件封装看Vue的作用域插槽的实现
Feb 12 Javascript
vue+springboot+element+vue-resource实现文件上传教程
Oct 21 Javascript
小程序实现上下切换位置
Nov 16 Javascript
Bootstrap Table使用整理(三)
Jun 09 #Javascript
Bootstrap Table使用整理(二)
Jun 09 #Javascript
Bootstrap Table使用整理(一)
Jun 09 #Javascript
Bootstrap Table使用整理(五)之分页组合查询
Jun 09 #Javascript
JS实现简易的图片拖拽排序实例代码
Jun 09 #Javascript
jQuery为某个div加入行样式
Jun 09 #jQuery
Vue.js中轻松解决v-for执行出错的三个方案
Jun 09 #Javascript
You might like
php中spl_autoload详解
2014/10/17 PHP
php实现的xml操作类
2016/01/15 PHP
PHP简单实现DES加密解密的方法
2016/07/12 PHP
php实现将base64格式图片保存在指定目录的方法
2016/10/13 PHP
php微信公众平台交互与接口详解
2016/11/28 PHP
PHP基于关联数组20行代码搞定约瑟夫问题示例
2017/11/07 PHP
thinkphp5框架前后端分离项目实现分页功能的方法分析
2019/10/08 PHP
浅谈laravel 5.6 安装 windows上使用composer的安装过程
2019/10/18 PHP
prototype 学习笔记整理
2009/07/17 Javascript
JavaScript 滚轮事件使用说明
2010/03/07 Javascript
Prototype源码浅析 String部分(二)
2012/01/16 Javascript
JavaScript拆分字符串时产生空字符的解决方案
2014/09/26 Javascript
超级给力的JavaScript的React框架入门教程
2015/07/02 Javascript
JavaScript 2048 游戏实例代码(简单易懂)
2016/03/25 Javascript
AngularJS+Bootstrap3多级导航菜单的实现代码
2017/08/16 Javascript
深入理解Vue官方文档梳理之全局API
2017/11/22 Javascript
easyUI使用分页过滤器对数据进行分页操作实例分析
2020/06/01 Javascript
Vue watch响应数据实现方法解析
2020/07/10 Javascript
[54:53]2014 DOTA2国际邀请赛中国区预选赛 LGD-GAMING VS CIS 第二场
2014/05/23 DOTA
Python编程中对文件和存储器的读写示例
2016/01/25 Python
python3批量删除豆瓣分组下的好友的实现代码
2016/06/07 Python
Python从使用线程到使用async/await的深入讲解
2018/09/16 Python
正确理解Python中if __name__ == '__main__'
2019/01/24 Python
pyqt实现.ui文件批量转换为对应.py文件脚本
2019/06/19 Python
DJANGO-URL反向解析REVERSE实例讲解
2019/10/25 Python
Pytorch之卷积层的使用详解
2019/12/31 Python
Python flask框架端口失效解决方案
2020/06/04 Python
英国Flybe航空官网:欧洲最大的独立支线廉价航空公司
2019/07/15 全球购物
生物化工工艺专业应届生求职信
2013/10/08 职场文书
生产内勤岗位职责
2013/12/07 职场文书
开办饭店创业计划书
2013/12/28 职场文书
乡镇个人对照检查材料
2014/08/22 职场文书
团党委领导干部党的群众路线教育实践活动个人对照检查材料思想汇
2014/10/05 职场文书
元旦主持词开场白
2015/05/29 职场文书
2016年教师反腐倡廉心得体会
2016/01/13 职场文书
2016党风廉政建设心得体会范文
2016/01/25 职场文书