JavaScript设计模式样例十九 —— 职责链模式

职责链模式(Chain of Responsibility Pattern)

定义:为请求创建了一个接收者对象的链。
目的:避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。
场景:红楼梦中的"击鼓传花"。
// 采购请求
let PurchaseRequest = (amount, productName) => {
    this.amount = amount
    this.productName = productName
}

// 处理方
let Approver = (name, nextApprover) => {
    this.name = name
    this.nextApprover = nextApprover
}

Approver.prototype.processRequest = () => {
    throw new Error()
}

// ConcreteHandler
let Manager = (name, nextApprover) => {
    Approver.call(this, name, nextApprover)
}
extend(Manager, Approver)
Manager.prototype.processRequest = (request) => {
    if (request.Amount < 10000.0) {
        console.log('ok')
    } else if (NextApprover != null) {
        this.nextApprover.ProcessRequest(request)
    }
}


// ConcreteHandler,副总
let VicePresident = function (name, nextApprover) {
    Approver.call(this, name, nextApprover)
}
extend(VicePresident, Approver);
VicePresident.prototype.processRequest = function (request) {
    if (request.Amount < 25000.0) {
        console.log('ok');
    } else if (NextApprover != null) {
        this.nextApprover.ProcessRequest(request)
    }
}


// ConcreteHandler,总经理
let President = function (name, nextApprover) {
    Approver.call(this, name, nextApprover)
}
extend(President, Approver)
President.prototype.processRequest = function (request) {
    if (request.Amount < 100000.0) {
        console.log('ok')
    } else if (NextApprover != null) {
        this.nextApprover.ProcessRequest(request)
    }
}


let requestTelphone = new PurchaseRequest(4000.0, "Telphone")
let requestSoftware = new PurchaseRequest(10000.0, "Visual Studio")
let requestComputers = new PurchaseRequest(40000.0, "Computers")

let manager = new Manager("LearningHard")
let Vp = new VicePresident("Tony")
let Pre = new President("BossTom")

// 设置责任链
manager.NextApprover = Vp
Vp.NextApprover = Pre

// 处理请求
manager.ProcessRequest(requestTelphone)
manager.ProcessRequest(requestSoftware)
manager.ProcessRequest(requestComputers)

Git地址:https://github.com/skillnull/Design-Mode-Example

posted @   SKILL·NULL  阅读(148)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
历史上的今天:
2016-03-25 CSS3混合模式background-blend-mode
点击右上角即可分享
微信分享提示