JS设计模式之责任链模式实例详解


Posted in Python onFebruary 03, 2018

本文实例讲述了JS设计模式之责任链模式。分享给大家供大家参考,具体如下:

责任链设计模式:

在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链。请求在这个链上传递,直到链上的某一个对象决定处理此请求。发出这个请求的客户端并不知道链上的哪一个对象最终处理这个请求,这使得系统可以在不影响客户端的情况下动态地重新组织和分配责任。

责任链模式涉及到的角色如下所示:

● 抽象处理者(Handler)角色:定义出一个处理请求的接口。如果需要,接口可以定义 出一个方法以设定和返回对下家的引用。这个角色通常由一个Java抽象类或者Java接口实现。上图中Handler类的聚合关系给出了具体子类对下家的引用,抽象方法handleRequest()规范了子类处理请求的操作。

● 具体处理者(ConcreteHandler)角色:具体处理者接到请求后,可以选择将请求处理掉,或者将请求传给下家。由于具体处理者持有对下家的引用,因此,如果需要,具体处理者可以访问下家。

JS设计模式之责任链模式实例详解

在JS(ES6之前)中严格意义上是没有extends继承概念,所以以下代码没有模拟抽象类,代码中只实现了具体处理类.

使用场景:在一个购物商城,在五一做了一个活动,所以图书类商品根据购买的金额依次做出以下折扣方案,

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

责任链链的优点:

请求发送者只需要知道链中的第一个节点,从而弱化了发送者和一组接收者之间的强联系。如果不使用责任链链模式、根据当前价格客户端要知道每一级打折信息,最后知道具体是那一层上打折才是符合当前价格的折扣。

function BookHandler() {
 this.calcPrice = function( price ) {
  if ( 199 > price ) {
   console.log("原价是:"+ price);
  } else {
   this.successor.calcPrice( price );
  }
 }
 this.setSuccessor = function( _successor ) {
  this.successor = _successor;
 }
}
function BookCalc9Handler( _successor ) {
 this.calcPrice = function( price ) {
  if ( 199 <= price && price < 399 ) {
   console.log("原价是:"+ price +";打9折后:" + (price * 0.9));
  } else {
   this.successor.calcPrice( price );
  }
 }
 this.setSuccessor = function( _successor ) {
  this.successor = _successor;
 }
}
function BookCalc8Handler() {
 this.calcPrice = function( price ) {
  if ( 399 <= price && price < 599 ) {
   console.log("原价是:"+ price +";打8折后:" + (price * 0.8));
  } else {
   this.successor.calcPrice( price )
  }
 }
 this.setSuccessor = function( _successor ) {
  this.successor = _successor;
 }
}
function BookCalc7Handler() {
 this.calcPrice = function( price ) {
  if ( price >= 599 ) {
   console.log("原价是:"+ price +";打7折后:" + (price * 0.7));
  } else {
   this.successor.calcPrice( price )
  }
 }
 this.setSuccessor = function( _successor ) {
  this.successor = _successor;
 }
}

客户端 :

var price = 400;
var bookHandler = new BookHandler();
var bookCalc9Handler = new BookCalc9Handler();
var bookCalc8Handler = new BookCalc8Handler();
var bookCalc7Handler = new BookCalc7Handler();
bookHandler.setSuccessor(bookCalc9Handler);
bookCalc9Handler.setSuccessor(bookCalc8Handler);
bookCalc8Handler.setSuccessor(bookCalc7Handler);
bookHandler.calcPrice(price);

Console.log打印出来的效果:

JS设计模式之责任链模式实例详解

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

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

Python 相关文章推荐
从零学python系列之数据处理编程实例(二)
May 22 Python
python+ffmpeg视频并发直播压力测试
Mar 06 Python
python清除字符串中间空格的实例讲解
May 11 Python
详解python中的装饰器
Jul 10 Python
Python实现输入二叉树的先序和中序遍历,再输出后序遍历操作示例
Jul 27 Python
使用matlab或python将txt文件转为excel表格
Nov 01 Python
python 线性回归分析模型检验标准--拟合优度详解
Feb 24 Python
Python基于pyecharts实现关联图绘制
Mar 27 Python
python中format函数如何使用
Jun 22 Python
Flask缓存静态文件的具体方法
Aug 02 Python
python中把元组转换为namedtuple方法
Dec 09 Python
python脚本框架webpy模板控制结构
Nov 20 Python
numpy使用技巧之数组过滤实例代码
Feb 03 #Python
python验证码识别实例代码
Feb 03 #Python
Django中cookie的基本使用方法示例
Feb 03 #Python
Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法
Feb 03 #Python
Python数据分析之双色球统计单个红和蓝球哪个比例高的方法
Feb 03 #Python
Python数据分析之双色球中蓝红球分析统计示例
Feb 03 #Python
Python数据分析之获取双色球历史信息的方法示例
Feb 03 #Python
You might like
用php来检测proxy
2006/10/09 PHP
第四章 php数学运算
2011/12/30 PHP
基于php实现长连接的方法与注意事项的问题
2013/05/10 PHP
PHP中常用的输出函数总结
2014/09/22 PHP
php在数据库抽象层简单使用PDO的方法
2015/11/03 PHP
PHP小偷程序的设计与实现方法详解
2016/10/15 PHP
jQuery 常见学习网站与参考书
2009/11/09 Javascript
JavaScript isArray()函数判断对象类型的种种方法
2010/10/11 Javascript
浅谈jquery.fn.extend与jquery.extend区别
2015/07/13 Javascript
javascript常用正则表达式汇总
2015/07/31 Javascript
jquery实现在网页指定区域显示自定义右键菜单效果
2015/08/25 Javascript
Bootstrap布局方式详解
2016/05/27 Javascript
JS使用单链表统计英语单词出现次数
2016/06/16 Javascript
解决bootstrap导航栏navbar在IE8上存在缺陷的方法
2016/07/01 Javascript
bootstrapValidator自定验证方法写法
2016/12/01 Javascript
微信小程序 scroll-view组件实现列表页实例代码
2016/12/14 Javascript
vue-router路由简单案例介绍
2017/02/21 Javascript
在JS中如何把毫秒转换成规定的日期时间格式实例
2017/05/11 Javascript
BootStrap 导航条实例代码
2017/05/18 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
Windows下使用Nodejs运行js的方法
2017/09/02 NodeJs
Vue2.0用 watch 观察 prop 变化(不触发)
2017/09/08 Javascript
使用layui监听器监听select下拉框,事件绑定不成功的解决方法
2019/09/28 Javascript
js+canvas实现五子棋小游戏
2020/08/02 Javascript
在Python的Django框架中simple-todo工具的简单使用
2015/05/30 Python
python版本的读写锁操作方法
2016/04/25 Python
Python中数组,列表:冒号的灵活用法介绍(np数组,列表倒序)
2018/04/18 Python
python pygame实现方向键控制小球
2019/05/17 Python
django解决订单并发问题【推荐】
2019/07/31 Python
python读取大文件越来越慢的原因与解决
2019/08/08 Python
面向对象学习之pygame坦克大战
2019/09/11 Python
用python批量移动文件
2021/01/14 Python
《雨霖铃》听课反思
2014/02/13 职场文书
大学生党员自我评价范文
2014/04/09 职场文书
Python django中如何使用restful框架
2021/06/23 Python
Python进行区间取值案例讲解
2021/08/02 Python