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实例教程(19) 使用HoTMetal(2)
Dec 23 Javascript
JQuery 拾色器插件发布-jquery.icolor.js
Oct 20 Javascript
小结Node.js中非阻塞IO和事件循环
Sep 18 Javascript
Javascript显示和隐藏ul列表的方法
Jul 15 Javascript
微信小程序 配置文件详细介绍
Dec 14 Javascript
了解VUE的render函数的使用
Jun 08 Javascript
基于Swiper实现移动端页面图片轮播效果
Dec 28 Javascript
vue如何判断dom的class
Apr 26 Javascript
浅析Vue.js 中的条件渲染指令
Nov 19 Javascript
详解小程序input框失焦事件在提交事件前的处理
May 05 Javascript
一篇文章带你搞懂Vue虚拟Dom与diff算法
Aug 25 Javascript
浏览器JavaScript调试功能无法使用解决方案
Sep 18 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
一个ubbcode的函数,速度很快.
2006/10/09 PHP
PHP base64+gzinflate压缩编码和解码代码
2008/10/03 PHP
ThinkPHP之R方法实例详解
2014/06/20 PHP
WordPress中设置Post Type自定义文章类型的实例教程
2016/05/10 PHP
PHP7多线程搭建教程
2017/04/21 PHP
PHP新特性详解之命名空间、性状与生成器
2017/07/18 PHP
laravel高级的Join语法详解以及使用Join多个条件
2019/10/16 PHP
Javascript实现的常用算法(如冒泡、快速、鸽巢、奇偶等)
2014/04/29 Javascript
jquery 显示*天*时*分*秒实现时间计时器
2014/05/07 Javascript
js动态删除div元素基本思路及实现代码
2014/05/08 Javascript
vue2.0实战之使用vue-cli搭建项目(2)
2017/03/27 Javascript
bootstrap如何让dropdown menu按钮式下拉框长度一致
2017/04/10 Javascript
微信小程序中setInterval的使用方法
2017/09/29 Javascript
详解基于Vue,Nginx的前后端不分离部署教程
2018/12/04 Javascript
JavaScript canvas动画实现时钟效果
2020/02/10 Javascript
vue 组件简介
2020/07/31 Javascript
JavaScript中条件语句的优化技巧总结
2020/12/04 Javascript
Vue组件简易模拟实现购物车
2020/12/21 Vue.js
python Django连接MySQL数据库做增删改查
2013/11/07 Python
Python3实现Web网页图片下载
2016/01/28 Python
Django Celery异步任务队列的实现
2019/07/24 Python
scrapy头部修改的方法详解
2020/12/06 Python
CSS3中Animation动画属性用法详解
2016/07/04 HTML / CSS
Html5 localStorage入门教程
2018/04/26 HTML / CSS
美国在线印刷公司:PsPrint
2017/10/12 全球购物
什么是GWT的Module
2013/01/20 面试题
业务主管岗位职责
2013/11/20 职场文书
医院护士专业个人的求职信
2013/12/09 职场文书
应届毕业生个人求职信范文
2014/01/29 职场文书
《找不到快乐的波斯猫》教学反思
2014/02/24 职场文书
行政处罚告知书
2015/07/01 职场文书
2015小学毕业班工作总结
2015/07/21 职场文书
2015年计算机教学工作总结
2015/07/22 职场文书
导游词之广西漓江
2019/11/02 职场文书
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
2021/06/13 Python
Nginx反向代理配置的全过程记录
2021/06/22 Servers