JS設(shè)計模式---7.橋接模式

適用場合及栗子

  • 事件監(jiān)聽器

假設(shè)有一個名為getBeerById的API函數(shù)。它根據(jù)一個標識符返回有關(guān)某種啤酒的信息树枫。我們來給一個事件監(jiān)聽用戶操作

    //bad
    addEvent(Element,'click',getBeerById)
    function getBeerById(e){
      // 事件對象被作為參數(shù)傳遞給函數(shù),而本例并沒有使用這個參數(shù)景东,只是從this對象中獲取id
      var id = this.id;
      asyncRequest('GET',`beer.uri?id=${id}`,function (res) {
         console.log(`Request Beer:${res.responseText}`)  
      }) 
    }
    // good
    function getBeerById(id,callback) {
      asyncRequest('GET',`beer.uri?id=${id}`,function (res) {
        // 回調(diào) 傳入返回值
        callback(res.responseText)
      }) 
    }
    addEvent(Element,'click',getBeerByIdBridge)
    function getBeerByIdBridge(e){
      // 把id作為參數(shù)傳遞給getBeerById函數(shù)是合情合理的团赏,這里使用一個回調(diào)函數(shù)把回應(yīng)結(jié)果返回 現(xiàn)在我們將針對接口而不是實現(xiàn)進行編程 
      getBeerById(this.id,function (beer) {
        console.log(`Request Beer:${res.responseText}`)
      })
    }

我們用了兩種方式來實現(xiàn),第一種方式把事件對象與getBeerById捆綁在一起耐薯,那么它只在本次事件中適用舔清。第二種方式使用橋接模式把抽象隔離開來后丝里,getBeerById 函數(shù)不再和事件對象捆綁在一起,也就擴大了它的適用范圍

  • 特權(quán)函數(shù)
  var Public = function () {
     var secret = 3;
     this.privilegedGetter = function () {
       return secret
     }
   }
   var o = new Public();
   var data = o.privilegedGetter();

利用橋接函數(shù)來實現(xiàn)公共成員對私有成員的訪問和操作 詳見封裝

  • 連接多個類
  var class1 = function (a,b,c) {
    this.a = a;
    this.b = b;
    this.c = c;
  }
  var class2 = function (d) {
    this.d = d
  }
  var BridgeClass = function (a,b,c,d) {
    this.one = new class1(a,b,c);
    this.two = new clsaa2(d);
  }

這看起來很像適配器体谒,但是本例中實際上并沒有客戶系統(tǒng)要求提供數(shù)據(jù)杯聚,它只不過是用來接納數(shù)據(jù)并轉(zhuǎn)發(fā)給責任方的一種輔助性手段。
有人可能會覺得這個橋接類實際上就是一個門面類抒痒。但是這里與門面類不同幌绍,使用橋接模式是為了讓class1和class2能夠獨立于BrigeClass而發(fā)生改變。

總結(jié)

橋接模式主要的作用是將抽象與其實現(xiàn)隔離開來故响,以便二者獨立變化傀广,互不影響。
橋接模式的好處就在于能夠獨立管理你項目的各個組成部分彩届,可以促進代碼的模塊化伪冰,促成更簡潔的實現(xiàn)并提高抽象的靈活性。
只有某一處調(diào)用的函數(shù)如果用橋接的話樟蠕,代碼就會變得累贅了贮聂。而且增加了函數(shù)的調(diào)用,可能會對性能造成一些影響寨辩。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吓懈,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子靡狞,更是在濱河造成了極大的恐慌耻警,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甸怕,死亡現(xiàn)場離奇詭異榕栏,居然都是意外死亡,警方通過查閱死者的電腦和手機蕾各,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庆揪,“玉大人式曲,你說我怎么就攤上這事「组唬” “怎么了吝羞?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長内颗。 經(jīng)常有香客問我钧排,道長,這世上最難降的妖魔是什么均澳? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任恨溜,我火速辦了婚禮符衔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘糟袁。我一直安慰自己判族,他們只是感情好,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布项戴。 她就那樣靜靜地躺著形帮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪周叮。 梳的紋絲不亂的頭發(fā)上辩撑,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天,我揣著相機與錄音仿耽,去河邊找鬼合冀。 笑死,一個胖子當著我的面吹牛氓仲,可吹牛的內(nèi)容都是我干的水慨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼敬扛,長吁一口氣:“原來是場噩夢啊……” “哼晰洒!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起啥箭,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤谍珊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后急侥,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體砌滞,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年坏怪,在試婚紗的時候發(fā)現(xiàn)自己被綠了贝润。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡铝宵,死狀恐怖打掘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情鹏秋,我是刑警寧澤尊蚁,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站侣夷,受9級特大地震影響横朋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜百拓,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一琴锭、第九天 我趴在偏房一處隱蔽的房頂上張望晰甚。 院中可真熱鬧,春花似錦祠够、人聲如沸压汪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽止剖。三九已至,卻和暖如春落君,著一層夾襖步出監(jiān)牢的瞬間穿香,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工绎速, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留皮获,地道東北人。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓纹冤,卻偏偏與公主長得像亲铡,于是被迫代替她去往敵國和親更米。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

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

  • 設(shè)計模式概述 在學(xué)習(xí)面向?qū)ο笃叽笤O(shè)計原則時需要注意以下幾點:a) 高內(nèi)聚、低耦合和單一職能的“沖突”實際上沾凄,這兩者...
    彥幀閱讀 3,741評論 0 14
  • 設(shè)計模式匯總 一礼仗、基礎(chǔ)知識 1. 設(shè)計模式概述 定義:設(shè)計模式(Design Pattern)是一套被反復(fù)使用辱志、多...
    MinoyJet閱讀 3,939評論 1 15
  • 本文旨在快速梳理常用的設(shè)計模式云石,了解每個模式主要針對的是哪些情況以及其基礎(chǔ)特征,每個模式前都有列舉出一個或多個可以...
    蠻三刀醬閱讀 1,781評論 0 1
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴謹 對...
    cosWriter閱讀 11,097評論 1 32
  • 隨筆1 我聽著情歌懷念你求妹,總有那么幾句說進我心里乏盐, 回憶與歌曲的畫面重疊著,好似你笑著對我說你也在想我制恍, 淚在眼眶...
    喪_半日仙閱讀 175評論 0 0