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.GetAllChild(element,deep,condition)使用介绍
Sep 21 Javascript
jQuery判断div随滚动条滚动到一定位置后停止
Apr 02 Javascript
javascript 动态创建表格
Jan 08 Javascript
jQuery实现当前页面标签高亮显示的方法
Mar 10 Javascript
jQuery实现拼图小游戏(实例讲解)
Jul 24 jQuery
简单实现js拖拽效果
Jul 25 Javascript
原生JS写Ajax的请求函数功能
Dec 22 Javascript
jQuery实现浏览器之间跳转并传递参数功能【支持中文字符】
Mar 28 jQuery
实现Vue的markdown文档可以在线运行的方法示例
Dec 11 Javascript
微信小程序通过一个json实现分享朋友圈图片
Sep 03 Javascript
ES6 十大特性简介
Dec 09 Javascript
JavaScript canvas实现雨滴特效
Jan 10 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实现获取及设置用户访问页面语言类
2014/09/24 PHP
Laravel 5框架学习之表单验证
2015/04/08 PHP
PHP异常处理浅析
2015/05/12 PHP
PHP实现图片自动清理的方法
2015/07/08 PHP
php+ajax实现仿百度查询下拉内容功能示例
2017/10/20 PHP
PHP使用Session实现上传进度功能详解
2019/08/06 PHP
javascript concat数组累加 示例
2009/09/03 Javascript
setTimeout和setInterval的区别你真的了解吗?
2011/03/31 Javascript
在Iframe中获取父窗口中表单的值(示例代码)
2013/11/22 Javascript
Jquery树插件zTree用法入门教程
2015/02/17 Javascript
JavaScript实现审核流程状态的动态显示进度条
2017/03/15 Javascript
jQuery自定义图片上传插件实例代码
2017/04/04 jQuery
nodejs创建简易web服务器与文件读写的实例
2017/09/07 NodeJs
ES6 javascript中class静态方法、属性与实例属性用法示例
2017/10/30 Javascript
MVVM框架下实现分页功能示例
2018/06/14 Javascript
Vue中使用webpack别名的方法实例详解
2018/06/19 Javascript
JavaScript函数、闭包、原型、面向对象学习笔记
2018/09/06 Javascript
浅析vue中的MVVM实现原理
2019/03/04 Javascript
JS实现烟花爆炸效果
2020/03/10 Javascript
js实现星星打分效果
2020/07/05 Javascript
python使用urllib2实现发送带cookie的请求
2015/04/28 Python
python如何派生内置不可变类型并修改实例化行为
2018/03/21 Python
python实现单链表中删除倒数第K个节点的方法
2018/09/28 Python
500行Python代码打造刷脸考勤系统
2019/06/03 Python
通过python3实现投票功能代码实例
2019/09/26 Python
python实现UDP协议下的文件传输
2020/03/20 Python
Python中生成ndarray实例讲解
2021/02/22 Python
详解HTML5 Canvas绘制不规则图形时的非零环绕原则
2016/03/21 HTML / CSS
自考生自我评价分享
2014/01/18 职场文书
保险内勤岗位职责
2014/04/05 职场文书
党员先锋岗事迹材料
2014/05/08 职场文书
重阳节活动总结
2014/08/27 职场文书
2014年班长个人工作总结
2014/11/14 职场文书
思想品德评语大全
2014/12/31 职场文书
工程部岗位职责范本
2015/04/11 职场文书
关于React Native 无法链接模拟器的问题
2021/06/21 Javascript