我的编程空间,编程开发者的网络收藏夹
学习永远不晚

javascript职责链模式的代码怎么写

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

javascript职责链模式的代码怎么写

这篇“javascript职责链模式的代码怎么写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“javascript职责链模式的代码怎么写”文章吧。

职责链的定义:使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象能处理它为止,传递链中的这些对象就叫节点。

需求背景: 一个电商网站,用户交500定金且定金已付时,可享受500优惠券且不受货物数量限制;用户交200定金且定金已付时,可享受500优惠券且不受货物数量限制;用户不交定金时受货物数量限制,有货时原价买,无货时则无法买。

原始版本, if else一路判断

var buyOrder = function(orederType, pay, stock){    if(orederType == 1){        if(pay){            console.log('500优惠券');        }else {            if(stock > 0){                console.log('普通购物页面');            }else {                console.log('已无货');            }        }    }else if(orederType == 2){        if(pay){            console.log('200优惠券');        }else {            if(stock > 0){                console.log('普通购物页面');            }else {                console.log('已无货');            }        }    }else if(orederType == 3){        if(stock > 0){            console.log('普通购物页面');        }else {            console.log('已无货');        }    }}buyOrder(1, true, 600)

改进版本

var order500 = function(orderType, pay , stock){    if(orderType == '1' && pay == true){        console.log('500优惠券');    }else {        order200(orderType, pay , stock)    }}var order200 = function(orderType, pay , stock){    if(orderType == '2' && pay == true){        console.log('200优惠券');    }else {        orderNormal(orderType, pay , stock)    }}var orderNormal = function(orderType, pay , stock){    if(stock > 0){        console.log('普通购物页面');    }else {        console.log('已无货');    }}order500(3, true, 0)

优化版本1:
同步的职责链

//3个订单函数 ,它们都是节点函数var order500 = function(orderType, pay , stock){    if(orderType == '1' && pay == true){        console.log('500优惠券');    }else {        return 'nextSuccessor';     //我不知道下个节点是谁,反正把请求往后传递    }}var order200 = function(orderType, pay , stock){    if(orderType == '2' && pay == true){        console.log('200优惠券');    }else {        return 'nextSuccessor';     //我不知道下个节点是谁,反正把请求往后传递    }}var orderNormal = function(orderType, pay , stock){    if(stock > 0){        console.log('普通购物页面');    }else {        console.log('已无货');    }}//职责构造函数var Chain = function(fn){    this.fn = fn;    this.successor = null;}Chain.prototype.setNextSuccessor = function(successor){     //设置职责顺序方法    this.successor = successor}Chain.prototype.passRequest = function(){       //请求传递    var ret = this.fn.apply(this, arguments)    if(ret === 'nextSuccessor'){        return this.successor && this.successor.passRequest.apply(this.successor, arguments)    }    return ret;}//把3个订单函数分别包装成职责链的节点var chainOrder500 = new Chain(order500)var chainOrder200 = new Chain(order200)var chainOrderNormal = new Chain(orderNormal)//然后指定节点在职责链中的顺序chainOrder500.setNextSuccessor(chainOrder200)chainOrder200.setNextSuccessor(chainOrderNormal)//最后把请求传递给第一个节点,开启职责链模式传递chainOrder500.passRequest(1, true, 500)     //500优惠券chainOrder500.passRequest(3, true, 20)      //普通购物页面chainOrder500.passRequest(3, true, 0)       //已无货//此时如果中间有需求改动,只需如此做: var order300 = function(){    if(orderType == '3' && pay == true){        console.log('300优惠券');    }else {        return 'nextSuccessor';     //我不知道下个节点是谁,反正把请求往后传递    }}var chainOrder300 = new Chain(order300)     //添加新职责节点chainOrder500.setNextSuccessor(chainOrder300)chainOrder300.setNextSuccessor(chainOrder300)   //修改职责链顺序chainOrder200.setNextSuccessor(chainOrderNormal)//这样,就可以完全不必去理会原来的订单函数代码,只需增加一个节点,然后重新设置职责链中的相关节点的顺序就行。

优化版本2:异步的职责链

在实际开发中,经常会遇到 一些异步的问题,比如要在节点函数中发起一个ajax请求,异步请求返回的结果才能决定是否继续在职责链中passRequest

可以给Chain类再增加一个原型方法:

//职责构造函数var Chain = function(fn){    this.fn = fn;    this.successor = null;}Chain.prototype.setNextSuccessor = function(successor){     //设置职责顺序方法    this.successor = successor}Chain.prototype.passRequest = function(){       //请求传递    var ret = this.fn.apply(this, arguments)    if(ret === 'nextSuccessor'){    //传递给职责链中的下一个节点        return this.successor && this.successor.passRequest.apply(this.successor, arguments)    }    return ret;}//新增,表示手动传递请求给职责链中的下一个节点Chain.prototype.next = function(){    return this.successor && this.successor.passRequest.apply(this.successor, arguments)}//异步职责链例子var fn1 = new Chain(function(){    console.log(1);    return 'nextSuccessor'})var fn2 = new Chain(function(){    console.log(2);    var self = this;    setTimeout(function(){        self.next()    }, 1000)})var fn3 = new Chain(function(){    console.log(3);})//指定节点在职责链中的顺序fn1.setNextSuccessor(fn2)fn2.setNextSuccessor(fn3)//把请求传递给第一个节点,开始节点传递fn1.passRequest()//输出 1 2 ...(1秒后)... 3//这是一个异步职责链,请求在职责链节点中传递,但节点有权利决定什么时候 把请求交给下一个节点。这样可以创建一个异步ajax队列库。

tips:

这里补充个知识点:“短路求值” && 会返回第一个假值(0, null, "", undefined, NaN),而 || 则会返回第一个真值。

var x = a || b || c 等价于:

var x;if(a){    x = a;} else if(b){    x = b;} else {    x = c;}

var x = a && b && c 等价于:

var x = a;if(a){    x = b;    if(b){        x = c;    }}

所以 && 有时候会用来代替 if (expression) doSomething(),转成 &&方式就是 expression && doSomething()

而 || 比较用来在函数中设置默认值,比如:

function doSomething(arg1, arg2, arg3) {    arg1 = arg1 || 'arg1Value';    arg2 = arg2 || 'arg2Value';}

不过还需要看具体的使用场景,就比如如果要求 doSomething() 传入的 arg1 为一个数值,则上面的写法就会出现问题(在传入 0 的时候被认为是一个假值而使用默认值)。

现在个人比较常用的方法只判断是否与 undefined 相等,比如

function doSomething(arg) {    arg = arg !== void 0 ? arg : 0;}

职责链模式的优势:解耦请求发送者和 N 个接收者之间的复杂关系,由于不知道链条中的哪个节点可以处理你发出的请求,所以只需把请求传递给第一个节点就行。

如果在实际开发中,当维护一个含有多个条件分支语句的巨大函数时时,可以使用职责链模式。链中的节点对象可以灵活拆分重组,增加删除节点,且无需改动其他节点函数内的代码。

以上就是关于“javascript职责链模式的代码怎么写”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

javascript职责链模式的代码怎么写

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

javascript职责链模式的代码怎么写

这篇“javascript职责链模式的代码怎么写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“javascript职责链模式
2023-06-27

C语言责任链模式代码怎么写

这篇文章主要讲解了“C语言责任链模式代码怎么写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言责任链模式代码怎么写”吧!介绍:责任链模式是一种行为模式,它可以允许你将请求沿着处理者链进行
2023-06-22

GoLang职责链模式代码实现介绍

这篇文章主要介绍了GoLang职责链模式代码实现,职责链模式是一种常用的设计模式,可以提高代码的灵活性与可维护性,职责链模式将请求和处理分离,可以让请求在处理链中依次经过多个处理者,直到找到能够处理请求的处理者为止
2023-05-19

Java职责链模式怎么实现

本篇内容主要讲解“Java职责链模式怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java职责链模式怎么实现”吧!一、职责链模式的定义与特点定义:为了避免请求发送者与多个请求处理者耦合在
2023-06-22

JavaScript设计模式之职责链模式的示例分析

小编给大家分享一下JavaScript设计模式之职责链模式的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!java基本数据类型有哪些Java的基本数据类型
2023-06-14

C++单一职责原则的代码怎么写

今天小编给大家分享一下C++单一职责原则的代码怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。单一职责原则:就一个类而言
2023-07-05

javascript中介者模式的代码怎么写

这篇文章主要介绍“javascript中介者模式的代码怎么写”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“javascript中介者模式的代码怎么写”文章能帮助大家解决问题。中介者对象践行了最少知识
2023-06-27

Java设计模式中的责任链怎么实现

本篇内容介绍了“Java设计模式中的责任链怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!责任链模式(Chain of Respons
2023-06-17

c++单例模式的代码怎么写

下面是一个简单的C++单例模式的代码示例:class Singleton {private:static Singleton* instance;Singleton() {} // 将构造函数设为私有,防止外部创建对象public:st
2023-10-26

java设计模式的单一职责原则怎么实现

这篇“java设计模式的单一职责原则怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“java设计模式的单一职责原则怎么
2023-06-17

JavaScript实现拖动模态框的代码怎么写

这篇文章主要介绍“JavaScript实现拖动模态框的代码怎么写”,在日常操作中,相信很多人在JavaScript实现拖动模态框的代码怎么写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript实
2023-07-02

C++链栈的实现代码怎么写

这篇文章主要讲解了“C++链栈的实现代码怎么写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++链栈的实现代码怎么写”吧!链栈简述链栈从概念上看是链表和栈的结合,含有栈先进后出的特性,也具
2023-07-02

golang工厂模式实现代码怎么写

package mainimport (“fmt”)// 定义接口type Product interface {Use()}// 定义具体产品结构体type ConcreteProductA struct{}func
golang工厂模式实现代码怎么写
2024-02-29

java单例模式实现代码怎么写

在Java中实现单例模式有多种方式,以下是其中几种常用的实现方式:饿汉式(线程安全):public class Singleton {private static Singleton instance = new Singleton();p
2023-10-24

golang观察者模式实现的代码怎么写

在Go语言中实现观察者模式,可以按照以下步骤进行:定义主题(Subject)接口,包含以下方法:type Subject interface {Register(observer Observer) // 注册观察者Unregiste
2023-10-23

python遍历迭代器自动链式处理数据的代码怎么写

python遍历迭代器自动链式处理数据的代码怎么写,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。python遍历迭代器自动链式处理数据pytorch.utils.data可兼容
2023-06-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录