JS设计模式之策略模式概念与用法分析


Posted in Javascript onFebruary 05, 2018

本文实例讲述了JS设计模式之策略模式概念与用法。分享给大家供大家参考,具体如下:

策略模式的概念引用:

在软件开发中也常常遇到类似的情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法或者策略来完成该功能。

如查找、排序等,一种常用的方法是硬编码(Hard Coding)在一个类中,如需要提供多种查找算法,可以将这些算法写到一个类中,在该类中提供多个方法,每一个方法对应一个具体的查找算法;当然也可以将这些查找算法封装在一个统一的方法中,通过if…else…或者case等条件判断语句来进行选择。

这两种实现方法我们都可以称之为硬编码,如果需要增加一种新的查找算法,需要修改封装算法类的源代码;更换查找算法,也需要修改客户端调用代码。

在这个算法类中封装了大量查找算法,该类代码将较复杂,维护较为困难。如果我们将这些策略包含在客户端,这种做法更不可取,将导致客户端程序庞大而且难以维护,如果存在大量可供选择的算法时问题将变得更加严重.

举例说明:

一、出行旅游:我们可以有几个策略可以考虑:可以骑自行车,汽车,做火车,飞机。每个策略都可以得到相同的结果,但是它们使用了不同的资源。

选择策略的依据是费用,时间,使用工具还有每种方式的方便程度 。

二、在一个购物商城,在五一做了一个活动,所以图书类商品根据购买的金额做出以下折扣策略

1、购买满199元,打9折
2、购买满399元,打8折
3、购买满599元以上,打7折;

function BookStrategy() {
 this.calcPrice = function( price ) {
 console.log("未打折 = " + price);
 }
}
function BookCalc9Strategy() {
 this.calcPrice = function( price ) {
 console.log("原价是:"+ price +";打9折后:" + (price * 0.9));
 }
}
function BookCalc8Strategy() {
 this.calcPrice = function( price ) {
 console.log("原价是:"+ price +";打8折后:" + (price * 0.8));
 }
}
function BookCalc7Strategy() {
 this.calcPrice = function( price ) {
 console.log("原价是:"+ price +";打7折后:" + (price * 0.7));
 }
}
function PriceCalc( _strategy ) {
 this.strategy = _strategy;
 this.getPrice = function( price ) {
 return this.strategy.calcPrice( price );
 }
}
function Client() {
 var price = 100;
 var priceCalc = null;
 if ( 199 <= price && price < 399 ) {
 priceCalc = new PriceCalc(new BookCalc9Strategy());
 } else if ( 399 <= price && price < 599 ) {
 priceCalc = new PriceCalc(new BookCalc8Strategy());
 } else if ( 599 <= price ) {
 priceCalc = new PriceCalc(new BookCalc7Strategy());
 } else {
 priceCalc = new PriceCalc(new BookStrategy());
 }
 priceCalc.getPrice(price);
}
Client();

运行结果:

JS设计模式之策略模式概念与用法分析

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

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

Javascript 相关文章推荐
js word表格动态添加代码
Jun 07 Javascript
js 模拟气泡屏保效果代码
Jul 10 Javascript
JavaScript函数模式详解
Nov 07 Javascript
js实现鼠标经过时图片滚动停止的方法
Feb 16 Javascript
input输入框鼠标焦点提示信息
Mar 17 Javascript
JS事件添加和移出的兼容写法示例
Jun 20 Javascript
在网页中插入百度地图的步骤详解
Dec 02 Javascript
js使用i18n实现页面国际化的方法
May 09 Javascript
webpack2.0配置postcss-loader的方法
Aug 17 Javascript
Angular+Ionic使用queryParams实现跳转页传值的方法
Sep 05 Javascript
vue 导航守卫和axios拦截器有哪些区别
Dec 19 Vue.js
vue3种table表格选项个数的控制方法
Apr 14 Vue.js
Node.js成为Web应用开发最佳选择的原因
Feb 05 #Javascript
Node.js上传文件功能之服务端如何获取文件上传进度
Feb 05 #Javascript
javascript实现最长公共子序列实例代码
Feb 05 #Javascript
JS设计模式之访问者模式定义与用法分析
Feb 05 #Javascript
基于vue 动态加载图片src的解决方法
Feb 05 #Javascript
vue2.0 datepicker使用方法
Feb 04 #Javascript
js数组常用最重要的方法
Feb 04 #Javascript
You might like
PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数
2014/06/19 PHP
Yii调试查看执行SQL语句的方法
2016/07/15 PHP
javascript 鼠标拖动图标技术
2010/02/07 Javascript
在Javascript里访问SharePoint列表数据的实现方法
2011/05/22 Javascript
面向对象继承实例(a如何继承b问题)(自写)
2013/07/01 Javascript
Javascript中常见的校验如域名、手机、邮箱等等
2014/01/02 Javascript
setInterval与clearInterval的使用示例代码
2014/01/28 Javascript
javascript继承的六大模式小结
2015/04/13 Javascript
Javascript非构造函数的继承
2015/04/27 Javascript
JavaScript 拖拽实例代码
2016/09/21 Javascript
RequireJS简易绘图程序开发
2016/10/28 Javascript
详解基于Node.js的微信JS-SDK后端接口实现代码
2017/07/15 Javascript
关于vue.js发布后路径引用的问题解决
2017/08/15 Javascript
JavaScript中数组常见操作技巧
2017/09/01 Javascript
Angular中使用ng-zorro图标库部分图标不能正常显示问题
2019/04/22 Javascript
详解可以用在VS Code中的正则表达式小技巧
2019/05/14 Javascript
浅谈Vue.js之初始化el以及数据的绑定说明
2019/11/14 Javascript
Taro小程序自定义顶部导航栏功能的实现
2020/12/17 Javascript
详解Python中的循环语句的用法
2015/04/09 Python
python制作爬虫爬取京东商品评论教程
2016/12/16 Python
关于numpy中np.nonzero()函数用法的详解
2017/02/07 Python
Python实现的根据文件名查找数据文件功能示例
2018/05/02 Python
详解如何将python3.6软件的py文件打包成exe程序
2018/10/09 Python
python求最大值,不使用内置函数的实现方法
2019/07/09 Python
解决python3.6用cx_Oracle库连接Oracle的问题
2020/12/07 Python
WiFi云数码相框:Nixplay
2018/07/05 全球购物
美国美食礼品篮网站:Gourmet Gift Baskets
2019/12/15 全球购物
C#笔试题
2015/07/14 面试题
总经理岗位职责
2013/11/09 职场文书
商业门面租房协议书
2014/11/25 职场文书
工人先锋号事迹材料
2014/12/24 职场文书
办公用品质量保证书
2015/05/11 职场文书
Java面试题冲刺第十六天--消息队列
2021/08/07 面试题
Python matplotlib 利用随机函数生成变化图形
2022/04/26 Python
Vue组件化(ref,props, mixin,.插件)详解
2022/05/15 Vue.js
winserver2019安装软件一直卡在应用程序正在为首次使用做准备
2022/06/10 Servers