欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入理解JavaScript系列(38):設(shè)計(jì)模式之職責(zé)鏈模式詳解

 更新時(shí)間:2015年03月04日 09:11:57   投稿:junjie  
這篇文章主要介紹了深入理解JavaScript系列(38):設(shè)計(jì)模式之職責(zé)鏈模式詳解,職責(zé)鏈模式(Chain of responsibility)是使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求,從而避免請(qǐng)求的發(fā)送者和接受者之間的耦合關(guān)系,需要的朋友可以參考下

介紹

職責(zé)鏈模式(Chain of responsibility)是使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求,從而避免請(qǐng)求的發(fā)送者和接受者之間的耦合關(guān)系。將這個(gè)對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有一個(gè)對(duì)象處理他為止。

也就是說,請(qǐng)求以后,從第一個(gè)對(duì)象開始,鏈中收到請(qǐng)求的對(duì)象要么親自處理它,要么轉(zhuǎn)發(fā)給鏈中的下一個(gè)候選者。提交請(qǐng)求的對(duì)象并不明確知道哪一個(gè)對(duì)象將會(huì)處理它——也就是該請(qǐng)求有一個(gè)隱式的接受者(implicit receiver)。根據(jù)運(yùn)行時(shí)刻,任一候選者都可以響應(yīng)相應(yīng)的請(qǐng)求,候選者的數(shù)目是任意的,你可以在運(yùn)行時(shí)刻決定哪些候選者參與到鏈中。

正文

對(duì)于JavaScript實(shí)現(xiàn),我們可以利用其原型特性來實(shí)現(xiàn)職責(zé)鏈模式。

復(fù)制代碼 代碼如下:

var NO_TOPIC = -1;
var Topic;

function Handler(s, t) {
    this.successor = s || null;
    this.topic = t || 0;
}

Handler.prototype = {
    handle: function () {
        if (this.successor) {
            this.successor.handle()
        }
    },
    has: function () {
        return this.topic != NO_TOPIC;
    }
};


Handler只是接受2個(gè)參數(shù),第一個(gè)是繼任者(用于將處理請(qǐng)求傳下去),第二個(gè)是傳遞層級(jí)(可以用于控制在某個(gè)層級(jí)下是否執(zhí)行某個(gè)操作,也可以不用),Handler原型暴露了一個(gè)handle方法,這是實(shí)現(xiàn)該模式的重點(diǎn),先來看看如何使用上述代碼。

復(fù)制代碼 代碼如下:

var app = new Handler({
        handle: function () {
            console.log('app handle');
        }
    }, 3);

    var dialog = new Handler(app, 1);

    var button = new Handler(dialog, 2);

    button.handle();

改代碼通過原型特性,調(diào)用代碼從button.handle()->dialog.handle()->app.handle()->參數(shù)里的handle(),前三個(gè)都是調(diào)用原型的handle,最后才查找到傳入的參數(shù)里的handle,然后輸出結(jié)果,也就是說其實(shí)只有最后一層才處理。

那如何做到調(diào)用的時(shí)候,只讓dialog的這個(gè)對(duì)象進(jìn)行處理呢?其實(shí)可以定義dialog實(shí)例對(duì)象的handle方法就可以了,但需要在new button的之前來做,代碼如下:

復(fù)制代碼 代碼如下:

var app = new Handler({
        handle: function () {
            console.log('app handle');
        }
    }, 3);

    var dialog = new Handler(app, 1);
    dialog.handle = function () {
        console.log('dialog before ...')
        // 這里做具體的處理操作
        console.log('dialog after ...')
    };

    var button = new Handler(dialog, 2);

    button.handle();

該代碼的執(zhí)行結(jié)果即時(shí)dialog.handle里的處理結(jié)果,而不再是給app傳入的參數(shù)里定義的handle的執(zhí)行操作。

那能不能做到自身處理完以后,然后在讓繼任者繼續(xù)處理呢?答案是肯定的,但是在調(diào)用的handle以后,需要利用原型的特性調(diào)用如下代碼:

復(fù)制代碼 代碼如下:

Handler.prototype.handle.call(this);

該句話的意思說,調(diào)用原型的handle方法,來繼續(xù)調(diào)用其繼任者(也就是successor )的handle方法,以下代碼表現(xiàn)為:button/dialog/app三個(gè)對(duì)象定義的handle都會(huì)執(zhí)行。
復(fù)制代碼 代碼如下:

var app = new Handler({
    handle: function () {
        console.log('app handle');
    }
}, 3);

var dialog = new Handler(app, 1);
dialog.handle = function () {
    console.log('dialog before ...')
    // 這里做具體的處理操作
    Handler.prototype.handle.call(this); //繼續(xù)往上走
    console.log('dialog after ...')
};

var button = new Handler(dialog, 2);
button.handle = function () {
    console.log('button before ...')
    // 這里做具體的處理操作
    Handler.prototype.handle.call(this);
    console.log('button after ...')
};

button.handle();

通過代碼的運(yùn)行結(jié)果我們可以看出,如果想先自身處理,然后再調(diào)用繼任者處理的話,就在末尾執(zhí)行Handler.prototype.handle.call(this);代碼,如果想先處理繼任者的代碼,就在開頭執(zhí)行Handler.prototype.handle.call(this);代碼。

總結(jié)

職責(zé)鏈模式經(jīng)常和組合模式一起使用,這樣一個(gè)構(gòu)件的父構(gòu)件可以作為其繼任者。

同時(shí),DOM里的事件冒泡機(jī)制也和此好像有點(diǎn)類似,比如點(diǎn)擊一個(gè)按鈕以后,如果不阻止冒泡,其click事件將一直向父元素冒泡,利用這個(gè)機(jī)制也可以處理很多相關(guān)的問題,比如本系列設(shè)計(jì)模式享元模式里的《例1:事件集中管理》的示例代碼。

相關(guān)文章

  • Javascript中的數(shù)據(jù)類型之旅

    Javascript中的數(shù)據(jù)類型之旅

    JavaScript 是一種弱類型或者說動(dòng)態(tài)語言。這意味著你不用提前聲明變量的類型,在程序運(yùn)行過程中,類型會(huì)被自動(dòng)確定。這也意味著你可以使用同一個(gè)變量保存不同類型的數(shù)據(jù)。
    2015-10-10
  • 總結(jié)javascript三元運(yùn)算符知識(shí)點(diǎn)

    總結(jié)javascript三元運(yùn)算符知識(shí)點(diǎn)

    這是一篇關(guān)于javascript三元運(yùn)算符的相關(guān)基礎(chǔ)知識(shí)點(diǎn)內(nèi)容,大家可以學(xué)習(xí)一下鞏固基礎(chǔ)知識(shí)。
    2018-09-09
  • 簡易js代碼實(shí)現(xiàn)計(jì)算器操作

    簡易js代碼實(shí)現(xiàn)計(jì)算器操作

    正在學(xué)習(xí)javascript的朋友們,可以把這個(gè)小練習(xí)做一做,加強(qiáng)自己編寫代碼的能力
    2013-04-04
  • javascript中有趣的反柯里化深入分析

    javascript中有趣的反柯里化深入分析

    國內(nèi)對(duì)前端的研究在某些方面也不遜色于國外,反科里化的話題來自javascript之父Brendan Eich去年的一段twitter,需要深入理解的朋友可以參考本文
    2012-12-12
  • 帶你了解session和cookie作用原理區(qū)別和用法

    帶你了解session和cookie作用原理區(qū)別和用法

    這篇文章主要介紹了session和cookie作用原理,區(qū)別和用法,以及使用過程中的優(yōu)缺點(diǎn),通過列舉區(qū)別和原理,使讀者更能理解兩者之間的關(guān)系,需要的朋友可以參考下
    2017-08-08
  • 微信小程序開發(fā)之入門實(shí)例教程篇

    微信小程序開發(fā)之入門實(shí)例教程篇

    2016年推出微信小程序,時(shí)至今日,歷經(jīng)幾個(gè)版本的更新,已形成了相對(duì)實(shí)用和穩(wěn)定的服務(wù)平臺(tái)。本文簡單的介紹了微信小程序的入門用法,今后會(huì)繼續(xù)關(guān)注和實(shí)踐。需要的朋友可以參考學(xué)習(xí),下面來一起看看吧。
    2017-03-03
  • 關(guān)于textarea提交的內(nèi)容無法換行的解決辦法

    關(guān)于textarea提交的內(nèi)容無法換行的解決辦法

    本篇文章小編為大家介紹,關(guān)于textarea提交的內(nèi)容無法換行的解決辦法,有需要的朋友可以參考一下
    2013-04-04
  • 詳解JavaScript中undefined與null的區(qū)別

    詳解JavaScript中undefined與null的區(qū)別

    大多數(shù)計(jì)算機(jī)語言,有且僅有一個(gè)表示"無"的值,比如,C語言的NULL,Java語言的null,Python語言的none,Ruby語言的nil
    2014-03-03
  • js前端面試題及答案整理(一)

    js前端面試題及答案整理(一)

    各公司秋招很快就開始了,最近在準(zhǔn)備面試的東西,干脆將發(fā)現(xiàn)的各類面試題整理一下共享出來,大部分面試題是沒有標(biāo)準(zhǔn)答案的,我給出的答案也是僅供參考,如果有更好的解答歡迎在評(píng)論區(qū)留言
    2016-08-08
  • javascript學(xué)習(xí)筆記(五)原型和原型鏈詳解

    javascript學(xué)習(xí)筆記(五)原型和原型鏈詳解

    許多人對(duì)JavaScript的原型及原型鏈仍感到困惑,網(wǎng)上的文章又大多長篇大論,令讀者不明覺厲。我將用最簡潔明了的文字介紹JavaScript的原型及原型鏈。
    2014-10-10

最新評(píng)論