中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript實現職責鏈模式概述

發布時間:2020-10-10 08:34:29 來源:腳本之家 閱讀:114 作者:三十億少女的夢 欄目:web開發

什么是職責鏈模式

職責鏈模式的定義是:使多個對象都有機會處理請求,從而避免請求的發送者和接收者之間的耦合關系,將這些對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一個對象處理它為止。舉個例子:當你從公交車后門上車之后,你不可能直接把硬幣放到收款箱里面, 因為你不知道它在哪,那你就只能把硬幣給你前面一個人,讓他幫你傳到前面一個人手上,這樣一直傳遞到站在收款箱旁邊人的手上,由他把硬幣放到收款箱里面。

職責鏈模式思想

請求發送者只需要知道鏈中的第一個節點,從而弱化了發送者和一組接收者之間的強聯系。

JavaScript實現職責鏈模式(AOP方式)

 Function.prototype.after = function(fn) {
  var _self = this;

  return function () {
    var ret = _self.apply(this, arguments);
    if(ret === "nextSuccessor") {
     return fn.apply(this, arguments);
    }
    return ret;
  }
 }

是的沒錯,在JavaScript中實現職責鏈模式就是如此的簡單,如果對上面AOP代碼不了解可以參考我之前寫的這篇文章JavaScript實現AOP,這個方式和裝飾者模式看起來很像,從代碼上來看確實很像,但是他們的出發點是完全不同的

AOP實現裝飾者模式:在不改變已有函數內部的情況下添加一些新的功能,你可以想象一下同心圓,你每調用一次after,就相當于給你的圓外面又加了一個圓來包裹住它。注意它們是包含關系

AOP實現職責鏈模式:在函數執行之后確定是否執行下一個函數,你每次調用after,都相當于在已有函數之后添加一個函數,至于是否執行后面這個函數,取決于前一個函數的返回值。注意它們是鏈式關系

職責鏈模式實例

function cat (type) {
  if(type == "cat") {
    console.log("我是貓貓");
  } else {
    return "nextSuccessor"
  }
}

function dog (type) {
  if(type == "dog") {
    console.log("我是狗狗");
  } else {
    return "nextSuccessor"
  }
}

function pig (type) {
  if(type == "pig") {
    console.log("我是豬豬");
  } else {
    return "nextSuccessor"
  }
}

Function.prototype.after = function(fn) {
  var _self = this;

  return function () {
    var ret = _self.apply(this, arguments);
    if(ret === "nextSuccessor") {
      return fn.apply(this, arguments);
    }
    return ret;
  }
}


var pet = cat.after(dog).after(pig);

pet("pig"); //我是豬豬
pet("dog"); //我是狗狗
pet("cat"); //我是貓貓

請看上述代碼,我們給pet方法傳入了三個不同的參數,得到了不同的結果。拿第一次調用舉例,其執行過程是這樣的:傳入“pig”,先由cat方法判斷,cat方法發現自己處理不了,于是把“pig”傳遞給dog方法(return "nextSuccessor"來表示傳遞給下一個函數),dog方法發現自己也處理不了,再接著把“pig”傳遞到pig方法,pig方法可以處理,控制臺打印,我是豬豬。

你可能會覺得這不是浪費精神么,上述功能只需使用下面的幾行代碼就能解決,為何還要多寫上面那么多代碼

function pet(type) {
  if(type == "cat") {
    console.log("我是貓貓");
  } else if(type == "dog") {
    console.log("我是狗狗");
  } else if(type == "pig") {
    console.log("我是豬豬");
  }
}

pet("pig"); //我是豬豬
pet("dog"); //我是狗狗
pet("cat"); //我是貓貓

這樣看來,好像是簡單了很多。但是你有沒有考慮過,如果以后突然多了猴子這種動物,如果使用上面的垃圾代碼,那你就要去修改pet函數的源碼,多添加一條if語句判斷是不是猴子,其實這也還好,如果是加了1萬種動物呢?那你就要在pet這個函數里添加1萬條if語句,什么?還不夠浮夸?那你有沒有考慮過一種動物還會分很多品種,比如說貓咪分為長毛貓,短毛貓。這樣你的代碼就會涉及到嵌套if語句。恕我直言,現在你的代碼已經丑成狗了,嘻嘻

但是如果使用職責鏈模式,每多一個種動物,我們就給他定義一個函數,然后添加到職責鏈上,這樣一來,新的函數就和原來的函數高度解耦,豈不美哉?

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節
推薦閱讀:
  1. openstack概述
  2. API概述

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

杭锦旗| 吉木乃县| 沿河| 宁海县| 平遥县| 农安县| 遂昌县| 石家庄市| 常熟市| 沧源| 和硕县| 墨竹工卡县| 临沂市| 棋牌| 德安县| 宝鸡市| 观塘区| 怀宁县| 莱阳市| 壤塘县| 永和县| 丽水市| 兴城市| 无为县| 准格尔旗| 烟台市| 南皮县| 信阳市| 法库县| 乡城县| 日土县| 定兴县| 榆树市| 涪陵区| 舒城县| 杂多县| 嘉定区| 蕉岭县| 宝应县| 资源县| 广平县|