Typescript 職責(zé)鏈模式(Chain of Responsibility)

標(biāo)簽: 前端 設(shè)計(jì)模式 職責(zé)鏈模式 typescript Chain of Responsibility


請(qǐng)仔細(xì)閱讀下面代碼,理解其中的設(shè)計(jì)理念。

chain-of-responsibility.jpg

職責(zé)鏈模式

職責(zé)鏈模式: 職責(zé)鏈模式是用來(lái)消除消息的請(qǐng)求者和處理者之間的耦合的模式壳坪,尤其是在處理者有多個(gè)的情況下医窿。

實(shí)際場(chǎng)景

逛淘寶我們時(shí)巢狙担可以看到消費(fèi)滿多少立減多少,滿的多減的多躯肌。
這種根據(jù)用戶消費(fèi)的情況有不同的打折機(jī)制就會(huì)用到職責(zé)鏈模式來(lái)解除消息發(fā)送者和處理者之間的耦合。

職責(zé)鏈模式的結(jié)構(gòu)

  • Sender: 消息的發(fā)送者
  • Handler的抽象類(lèi): 處理者的抽象類(lèi)或接口
  • Handler: 各種處理者們

職責(zé)鏈模式的例子

現(xiàn)在有商場(chǎng)打折如下

普通折扣: 消費(fèi)不滿100元破衔,不打折
黃金折扣: 消費(fèi)滿100元清女,打9折
鉑金折扣: 消費(fèi)滿500元,打8折
鉆石折扣: 消費(fèi)滿1000元晰筛,打7折

我們用職責(zé)鏈模式
先定義抽象類(lèi)

/* handler-abstract-class.ts */
export abstract class HandlerAbstractClass {
    protected name: string;

    protected higherLevel: HandlerAbstractClass;

    constructor (name: string) {
        this.name = name;
    }

    public setHigherLevel (higherLever: HandlerAbstractClass) {
        this.higherLevel = higherLever;
    }

    public abstract handlerMessage (money: number)
}

定義幾個(gè)等級(jí)

/* level-1.ts */
import { HandlerAbstractClass } from './handler-abstract-class';

export class Level1 extends HandlerAbstractClass {
    public handlerMessage(money: number) {
        if (money < 100) {
            console.log(`您消費(fèi)${money}元嫡丙,當(dāng)前折扣為${this.name}折扣,還需支付${money}元`);
        } else {
            this.higherLevel.handlerMessage(money);
        }
    }
}
/* level-2.ts */
import { HandlerAbstractClass } from './handler-abstract-class';

export class Level2 extends HandlerAbstractClass {
    public handlerMessage(money: number) {
        if (money < 500) {
            console.log(`您消費(fèi)${money}元读第,當(dāng)前折扣為${this.name}折扣曙博,還需支付${money * 0.8}元`);
        } else {
            this.higherLevel.handlerMessage(money);
        }
    }
}
/* level-3.ts */
import { HandlerAbstractClass } from './handler-abstract-class';

export class Level3 extends HandlerAbstractClass {
    public handlerMessage (money: number) {
        if (money < 1000) {
            console.log(`您消費(fèi)${money}元,當(dāng)前折扣為${this.name}折扣卦方,還需支付${money * 0.7}元`);
        } else {
            this.higherLevel.handlerMessage(money);
        }
    }
}
/* level-4.ts */
import { HandlerAbstractClass } from './handler-abstract-class';

export class Level4 extends HandlerAbstractClass {
    public handlerMessage(money: number) {
        console.log(`您消費(fèi)${money}元羊瘩,當(dāng)前折扣為${this.name}折扣,還需支付${money * 0.6}元`);
    }
}

客戶端調(diào)用

/* client.ts */
import { Level1 } from './level-1';
import { Level2 } from './level-2';
import { Level3 } from './level-3';
import { Level4 } from './level-4';

export class Client {
    public static getDiscount(money: number) {
        const level4 = new Level4('鉆石');
        const level3 = new Level3('鉑金');
        const level2 = new Level2('黃金');
        const level1 = new Level1('普通');
        level2.setHigherLevel(level3);
        level1.setHigherLevel(level2);
        level1.handlerMessage(money);
    }
}
Client.getDiscount(1176);

職責(zé)鏈模式的利弊

利:

  • 有效的解除消息的發(fā)送者和處理者之間的耦合盼砍,可以更容易的模塊化和重構(gòu)、修改處理邏輯逝她。

弊:

  • 對(duì)象變多了之后浇坐,管理起來(lái)相對(duì)復(fù)雜了一點(diǎn)。
  • 在職責(zé)鏈中無(wú)法保證他一定被處理黔宛。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末近刘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子臀晃,更是在濱河造成了極大的恐慌觉渴,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件徽惋,死亡現(xiàn)場(chǎng)離奇詭異案淋,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)险绘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)踢京,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人宦棺,你說(shuō)我怎么就攤上這事瓣距。” “怎么了代咸?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵蹈丸,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng)逻杖,這世上最難降的妖魔是什么奋岁? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮弧腥,結(jié)果婚禮上厦取,老公的妹妹穿的比我還像新娘。我一直安慰自己管搪,他們只是感情好虾攻,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著更鲁,像睡著了一般霎箍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上澡为,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天漂坏,我揣著相機(jī)與錄音,去河邊找鬼媒至。 笑死顶别,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拒啰。 我是一名探鬼主播驯绎,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼谋旦!你這毒婦竟也來(lái)了剩失?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤册着,失蹤者是張志新(化名)和其女友劉穎拴孤,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體甲捏,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡演熟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了摊鸡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绽媒。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖免猾,靈堂內(nèi)的尸體忽然破棺而出是辕,到底是詐尸還是另有隱情,我是刑警寧澤猎提,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布获三,位于F島的核電站旁蔼,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏疙教。R本人自食惡果不足惜棺聊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贞谓。 院中可真熱鬧限佩,春花似錦、人聲如沸裸弦。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)理疙。三九已至晕城,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間窖贤,已是汗流浹背砖顷。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赃梧,地道東北人滤蝠。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像授嘀,于是被迫代替她去往敵國(guó)和親几睛。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容