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 相关文章推荐
Javascript表达式中连续的 &amp;&amp; 和 || 之赋值区别
Oct 17 Javascript
使用 Node.js 做 Function Test实现方法
Oct 25 Javascript
jquery中的过滤操作详细解析
Dec 02 Javascript
jquery 新建的元素事件绑定问题解决方案
Jun 12 Javascript
JQuery对ASP.NET MVC数据进行更新删除
Jul 13 Javascript
AngularJS中$watch和$timeout的使用示例
Sep 20 Javascript
js技巧之十几行的代码实现vue.watch代码
Jun 09 Javascript
微信小程序日历弹窗选择器代码实例
May 09 Javascript
jquery 插件重新绑定的处理方法分析
Nov 23 jQuery
微信小程序 自定义弹窗实现过程(附代码)
Dec 05 Javascript
小程序双头slider选择器的实现示例
Mar 31 Javascript
js实现3D旋转相册
Aug 02 Javascript
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入门教程之图像处理技巧分析
2016/09/11 PHP
PHP简单判断iPhone、iPad、Android及PC设备的方法
2016/10/11 PHP
老生常谈PHP数组函数array_merge(必看篇)
2017/05/25 PHP
ThinkPHP防止重复提交表单的方法实例分析
2018/05/10 PHP
thinkphp5.0整合phpsocketio完整攻略(绕坑)
2018/10/12 PHP
PHP中通过getopt解析GNU C风格命令行选项
2019/11/18 PHP
PHP pthreads v3使用中的一些坑和注意点分析
2020/02/21 PHP
jQuery学习笔记之jQuery的DOM操作
2010/12/22 Javascript
JS格式化数字金额用逗号隔开保留两位小数
2013/10/18 Javascript
js中生成map对象的方法
2014/01/09 Javascript
jquery实现全屏滚动
2015/12/28 Javascript
Node.js编写爬虫的基本思路及抓取百度图片的实例分享
2016/03/12 Javascript
jQuery validate+artdialog+jquery form实现弹出表单思路详解
2016/04/18 Javascript
jQuery事件用法详解
2016/10/06 Javascript
jQuery事件详解
2017/02/23 Javascript
jQuery插件echarts实现的单折线图效果示例【附demo源码下载】
2017/03/04 Javascript
react高阶组件经典应用之权限控制详解
2017/09/07 Javascript
node使用promise替代回调函数
2018/05/07 Javascript
详解Vue SPA项目优化小记
2018/07/03 Javascript
微信小程序实现自定义picker选择器弹窗内容
2020/05/26 Javascript
elementUI 动态生成几行几列的方法示例
2019/07/11 Javascript
python搭建简易服务器分析与实现
2012/12/15 Python
python通过ElementTree操作XML获取结点读取属性美化XML
2013/12/02 Python
Python学习笔记(一)(基础入门之环境搭建)
2014/06/05 Python
Python中的类学习笔记
2014/09/23 Python
python使用PyGame播放Midi和Mp3文件的方法
2015/04/24 Python
python字符类型的一些方法小结
2016/05/16 Python
Python编程之基于概率论的分类方法:朴素贝叶斯
2017/11/11 Python
Python中文件的读取和写入操作
2018/04/27 Python
记一次pyinstaller打包pygame项目为exe的过程(带图片)
2020/03/02 Python
CSS3打造磨砂玻璃背景效果
2016/09/28 HTML / CSS
京剧自荐信
2014/01/26 职场文书
县委班子四风对照检查材料思想汇报
2014/09/29 职场文书
2014年导购员工作总结
2014/11/18 职场文书
放牛班的春天观后感
2015/06/01 职场文书
create-react-app开发常用配置教程
2022/06/25 Javascript