JS設(shè)計模式之責任鏈模式應(yīng)用詳解
責任鏈模式(Chain of Responsibility Pattern)
定義:
一種行為型設(shè)計模式,它允許多個對象按照順序處理請求,直到其中一個對象能夠處理請求為止。這樣的對象鏈被稱為責任鏈。
特點:
在責任鏈模式中,每個處理請求的對象都有一個對下一個對象的引用,形成一個鏈條。
當客戶端發(fā)送請求時,請求會沿著鏈條傳遞,直到被某個處理器對象處理或者整個鏈條結(jié)束。
參與者:
抽象處理器(Abstract Handler):定義了處理請求的接口和維護下一個處理器的引用。通常實現(xiàn)為抽象類或接口。
具體處理器(Concrete Handler):具體實現(xiàn)了處理請求的方法。如果可以處理請求,則進行處理;否則將請求傳遞給下一個處理器。
工作流程:
客戶端創(chuàng)建并初始化責任鏈中的處理器對象,并設(shè)置好它們的處理順序。
當客戶端發(fā)送請求時,請求從鏈條的開頭開始傳遞。
每個處理器檢查自己是否能夠處理請求,如果可以,則進行處理并停止傳遞;否則將請求傳遞給下一個處理器。(這個過程必然會用到if else)
這個過程持續(xù)進行,直到請求被處理或者整個鏈條結(jié)束。
優(yōu)點:
解耦發(fā)送者和接收者,使得請求的發(fā)送者不需要知道哪個對象會處理請求。
可以動態(tài)地添加或修改處理器對象,從而避免將請求的處理邏輯硬編碼到單個對象中,增加了代碼的可維護性和可擴展性。
缺點:
整個鏈條的長度可能會對性能產(chǎn)生影響,特別是在鏈條非常長時。
使用場景:
處理者是動態(tài)的或者是不能預(yù)先確定的:有多個對象可以處理請求,但具體的處理者只在運行時確定
希望將請求的發(fā)送者和接收者解耦,讓請求可以自由地在對象之間傳遞。
示例:
// 抽象處理器 class Handler { ? nextHandler: Handler|null = null; ? setNext(handler: Handler) { ? ? this.nextHandler = handler; ? } ? abstract handleRequest(request: number): void; } // 具體處理器1 class ConcreteHandler1 extends Handler { ? handleRequest(request: number) { ? ? request <= 10 ? console.log(`Request ${request} handled by ConcreteHandler1`) : this.nextHandler?.handleRequest(request); ? } } // 具體處理器2 class ConcreteHandler2 extends Handler { ? handleRequest(request: number) { ? ? request > 10 && request <= 20 ? console.log(`Request ${request} handled by ConcreteHandler2`) : this.nextHandler?.handleRequest(request); ? } } // 具體處理器3 class ConcreteHandler3 extends Handler { ? handleRequest(request) { ? ? request > 20 && request <= 80 ? console.log(`Request ${request} handled by ConcreteHandler3`) : this.nextHandler?.handleRequest(request); ? } } // 異常處理器 class ConcreteHandlerX extends Handler { ? handleRequest(request) { ? ? throw new Error(`Request ${request} can not be handled by ConcreteHandler chain`); ? } } // 創(chuàng)建處理對象 const handler1 = new ConcreteHandler1(); const handler2 = new ConcreteHandler2(); const handler3 = new ConcreteHandler3(); const errorhandler = new ConcreteHandlerX(); // 處理對象成鏈 handler1.setNext(handler2); handler2.setNext(handler3); handler3.setNext(errorhandler); // 客戶端發(fā)送請求 handler1.handleRequest(5); ? // 輸出: Request 5 handled by ConcreteHandler1 handler2.handleRequest(15); ?// 輸出: Request 15 handled by ConcreteHandler2 handler3.handleRequest(25); ?// 輸出: Request 25 handled by ConcreteHandler3 handler1.handleRequest(90); ?// 直接報錯
原生實現(xiàn):
事件處理機制:在瀏覽器中,事件處理機制就是一個典型的責任鏈模式的應(yīng)用。當事件發(fā)生時,它會從目標元素開始沿著 DOM 樹向上傳播,每個元素都有機會處理該事件。如果某個元素無法處理事件,它會將事件傳遞給它的父級元素,直到找到能夠處理事件的元素或者事件冒泡至根元素。
中間件(Middleware)模式:在 Web 開發(fā)中,中間件模式也是一種常見的責任鏈模式的應(yīng)用。例如,Express.js 框架中的中間件允許你按照順序添加不同的中間件函數(shù)來處理 HTTP 請求。請求將依次經(jīng)過這些中間件函數(shù),每個中間件函數(shù)都有可能對請求進行處理、修改或者將請求傳遞給下一個中間件函數(shù)。
JavaScript Promise:Promise 是 JavaScript 中用于處理異步操作的一種機制。當使用 Promise 鏈式調(diào)用時,每個 Promise 對象都有一個
then()
方法,可以將回調(diào)函數(shù)添加到鏈條中。當前一個 Promise 對象執(zhí)行完成后,它會自動將結(jié)果傳遞給下一個 Promise 對象,形成一個責任鏈式的處理。jQuery Ajax:在 jQuery 的 Ajax 功能中,可以使用
$.ajax()
方法發(fā)送異步請求,并通過.done()
、.fail()
、.always()
等方法添加相應(yīng)的回調(diào)函數(shù)。這些回調(diào)函數(shù)可以按照順序連接起來,形成一個責任鏈,每個回調(diào)函數(shù)都有機會處理請求的結(jié)果。
總結(jié):
構(gòu)建抽象處理器類,然后子類具體處理器類重寫處理邏輯;實際化出不同的具體處理器類的實例對象,調(diào)用setNext方法成鏈,然后選擇鏈中某處作為入口,處理責任。
注意:不必從入口開始,因為可能在入鏈之前就已經(jīng)判斷過了,范圍已經(jīng)縮小了。
擴展:
鏈可以成環(huán),例如將handler3.setNext(errorhandler);
改成handler3.setNext(handler1);
, 從而責任傳遞永無停息,直到問題被解決。
用責任環(huán)結(jié)合定時器可以實現(xiàn)輪詢的效果。
到此這篇關(guān)于JS設(shè)計模式之責任鏈模式應(yīng)用詳解的文章就介紹到這了,更多相關(guān)JS責任鏈模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序?qū)崿F(xiàn)點擊按鈕修改字體顏色功能【附demo源碼下載】
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)點擊按鈕修改字體顏色功能,涉及微信小程序wx:for循環(huán)讀取data數(shù)值及事件綁定修改元素屬性相關(guān)操作技巧,需要的朋友可以參考下2017-12-12