内容简介:职责链模式在我们的开发中非常常见,然而在不知道的同学那里,可能你之前都是通过if/else的方式来实现的类似逻辑。职责链主要就是指,在执行一个具体的事情时,不确定使用哪种逻辑时,进行链式的判断,直到找到符合条件的函数或者对象,然后处理。分析,发现其实我们很多的代码的背后逻辑就是职责链模式。现实中的例子非常多,比如,我们在挤公交时,如果人特别多,我们之前是将硬币通过人传递的方式,依次向前传递,直到前面的人是司机或者售票员,这就是一个非常明显的职责链的例子。原先的代码主要是通过if,else进行不断的判断,执行
职责链模式在我们的开发中非常常见,然而在不知道的同学那里,可能你之前都是通过if/else的方式来实现的类似逻辑。职责链主要就是指,在执行一个具体的事情时,不确定使用哪种逻辑时,进行链式的判断,直到找到符合条件的函数或者对象,然后处理。分析,发现其实我们很多的代码的背后逻辑就是职责链模式。
图解
现实中的职责链
现实中的例子非常多,比如,我们在挤公交时,如果人特别多,我们之前是将硬币通过人传递的方式,依次向前传递,直到前面的人是司机或者售票员,这就是一个非常明显的职责链的例子。
代码重构
原先的代码主要是通过if,else进行不断的判断,执行不同的逻辑。
案例说明
重构前
const order = (orderType,pay,stock){ if(orderType === 1){ if(pay === true){ console.log('500元定金,返回100优惠券') } else { if(stock > 0 ){ consle.log('普通购买,无优惠券') } else { console.log('库存不足') } } } else if(orderType === 2){ if(pay === true){ console.log('200元定金,返回50优惠券') } else { if(stock > 0 ){ consle.log('普通购买,无优惠券') } else { console.log('库存不足') } } }else{ if(stock > 0 ){ consle.log('普通购买,无优惠券') } else { console.log('库存不足') } } } 复制代码
重构后
我们按照职责链的设计思想,一步到位,分别包含以下的思路:
- 将不同的购买模式封装为函数
- 实现链式函数,可以不断追加函数,可以在不符合时,实现递交
const order500 = function(orderType,pay,stock){ if(orderType === 1 && pay === true){ console.log('500元定金,返回100优惠券') } else { return 'nextSuccessor'; } } const order200 = function(orderType,pay,stock){ if(orderType === 2 && pay === true){ console.log('200元定金,返回50优惠券') } else { return 'nextSuccessor'; } } const orderNormal = function(orderType,pay,stock){ if(stock > 0 ){ console.log('普通购买,无优惠券') } else { console.log('库存不足') } } const Chain = function(fn){ this.fn = fn; this.successor = null; } Chain.prototype.setNextSuccessor = function(successor){ return this.successor = successor; } Chain.prototype.passRequest = function(){ let ret = this.fn.apply(this, arguments); if(ret === 'nextSuccessor'){ return this.successor && this.successor.passRequest.apply(this.successor, arguments); } return ret; } let chainOrder500 = new Chain(order500); let chainOrder200 = new Chain(order200); let chainOrderNormal = new Chain(orderNormal); chainOrder500.setNextSuccessor(chainOrder200); chainOrder200.setNextSuccessor(chainOrderNormal); chainOrder500.passRequest(1,false,0); chainOrder500.passRequest(1,true,10); chainOrder500.passRequest(2,true,11); chainOrder500.passRequest(2,false,1); 复制代码
codepen地址: codepen.io/robinson90/…
与策略模式的区别
乍一看,写法上,职责链与策略模式没什么,都是分别维护不同的函数逻辑,其区别主要是使用条件的判断。
策略模式可以准确的决定使用哪种策略,而且可以确定使用这种策略就能返回结果;而职责链模式,则是将使用条件进行抽象,内置到函数中,通过不断的函数内部判断,如果不符合,需要继续判断传递,直到执行到符合条件的函数并执行。
由此,我们可以这样判定,如果我们对条件属于模糊的,更适合使用职责链。这样要好于写if/else内写复杂的布尔运算,或者使用某个计算变量的结果值,或者使用其他函数的返回结果。
番外篇:职责驱动设计以及状态模式的实践
文章链接: mp.weixin.qq.com/s/qQEEnf79F…
需求
解决方案
引入职责驱动概念,从知识的能力的角度,去判断哪个对象具有操作的能力。
但这样的坏处是当加入新的状态时,所有实现接口的状态类都需要变更,不符合 设计模式 的开闭原则。
状态图:
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 设计模式-享元设计模式
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
人工智能的未来
Jeff Hawkins、Sandra Blakeslee / 贺俊杰、李若子、杨倩 / 陕西科学技术出版社 / 2006.1 / 18.5
陕西科技出版社最新引进美国图书《人工智能的未来》(On Intelligence)一书,是由杰夫•霍金斯,一位在硅谷极其成功、受人尊敬的计算机工程师、企业家与桑德拉•布拉克斯莉,《纽约日报》的栏目作家共同撰写。本书对人类大脑皮层所具有的知觉、认识、行为和智能功能新理论提出了新的理论构想。这一理论的独到之处在于对大脑皮层的现行认识提出了新的观点,对大脑的工作原理,即霍金斯称之为“真正智能”而非计算机......一起来看看 《人工智能的未来》 这本书的介绍吧!