首頁 web前端 js教程 詳細解讀JavaScript設計模式開發中的橋接模式(進階篇)

詳細解讀JavaScript設計模式開發中的橋接模式(進階篇)

May 21, 2018 pm 02:12 PM
javascript js 設計模式

橋接模式的適用場合非常廣泛,除了在事件回調函數與接口之間進行橋接外,橋接模式也可以用於連接公開的API代碼和私用的實現代碼,下面我們就來詳解JavaScript設計模式開發中的橋接模式使用

橋接模式將抽象部分與實現部分分離開來,使兩者都可以獨立的變化,並且可以一起和諧地工作。抽象部分和實作部分都可以獨立的變化而不會互相影響,降低了程式碼的耦合性,提高了程式碼的擴展性。
依照GoF的定義,橋接模式的功能在於「將抽象與其實現隔離開來,以便二者獨立變化」。這種模式對於Javascript中常見的事件驅動的程式設計大有裨益。

橋接模式最常見且實際的應用場合之一是事件監聽器回呼函數。 example:事件監聽器,把事件處理的語句封裝到回呼函數中,透過介面而不是實作進行程式設計。

基本理論

橋接模式定義:將抽象部分與它的實作部分分離,使它們都可以獨立地變更。
橋接模式主要有4個角色組成:
(1)抽象類別
(2)擴充抽象類別
(3)實作類別介面
(4)具體實作類別
根據javascript語言的特點,我們將其簡化成2個角色:
(1)擴充抽象類別
(2)具體實現類別
怎麼去理解橋接模式呢?我們接下來舉例說明

橋接模式的實作

理解橋接模式的思想,關鍵是要理解其分離抽象部分和實作部分的思想。我們舉例進行說明

最簡單的橋接模式

其實我們最常用的jQuery的each函數就是一個典型的橋接模式,我們模擬其實作如下:

var each = function (arr, fn) {
  for (var i = 0; i < arr.length; i++) {
    var val = arr[i];
    if (fn.call(val, i, val, arr)) {
      return false;
    }
  }
}
var arr = [1, 2, 3, 4];
each(arr, function (i, v) {
  arr[i] = v * 2;
})
登入後複製

在這個例子中,我們透過each函數循環了arr數組,別看這個例子很常見,但其中就包含了典型的橋接模式。
在這個例子中,抽象部分是each函數,也就是上面說的擴充抽象類,實作部分是fn,也就是具體實作類別。抽象部分和實作部分可以獨立的進行變更。這個例子雖然簡單,但就是一個典型的橋接模式的應用。

外掛程式開發中的橋接模式

橋接模式的一個適用場景是元件開發。我們平時開發組件為了適應不同場合,組件對應的會有許多不同維度的變化。橋接模式就可以應用於此,將其抽象與實作分離,使元件的擴展性更高。
假設我們要開發一個彈窗插件,彈窗有不同的類型:普通訊息提醒,錯誤提醒,每一種提醒的展示方式還都不一樣。這是一個典型的多維度變化的場景。首先我們定義兩個類別:普通訊息彈跳窗和錯誤訊息彈跳窗。

function MessageDialog(animation) {
  this.animation = animation;
}
MessageDialog.prototype.show = function () {
  this.animation.show();
}
function ErrorDialog(animation) {
  this.animation = animation;
}
ErrorDialog.prototype.show = function () {
  this.animation.show();
}
登入後複製

這兩個類別就是前面提到的抽象部分,也就是擴充抽象類,它們都包含一個成員animation。
兩種彈跳窗透過show方法進行顯示,但是顯示的動畫效果不同。我們定義兩種顯示的效果類別如下:

function LinerAnimation() {
}
LinerAnimation.prototype.show = function () {
  console.log("it is liner");
}
function EaseAnimation() {
}
EaseAnimation.prototype.show = function () {
  console.log("it is ease");
}
登入後複製

這兩個類別就是具體實作類,它們實現具體的顯示效果。那我們如何調用呢?

var message = new MessageDialog(new LinerAnimation());
message.show();
var error = new ErrorDialog(new EaseAnimation());
error.show();
登入後複製

如果我們要增加一種動畫效果,可以再定義一種效果類,傳入即可。

總結

學習橋接模式關鍵是要理解抽象部分與實現部分的分離,使得二者可以獨立的變化,而不必拘泥於形式。 JS插件靈活的變化,適用場景的多變就非常適合使用這種模式來實現。使用橋接模式最重要的是要找出系統中不同的變化維度。
(1)橋接模式優點:把抽象與實作隔離開,有助於獨立管理軟體的各組成部分。
(2)橋接模式缺點:每使用一個橋接元素都要增加一次函數調用,這對應用程式的效能會有一些負面影響。提高了系統的複雜程度。如果一個橋接函數被用來連接兩個函數,而其中某個函數根本不會在橋接函數之外被調用,那麼此時這個橋接函數就不是非要不可的。
橋接模式「將抽象與實現隔離開來,以便二者獨立變化」。它可以促進程式碼的模組化、促成更簡潔的實現並提高抽象的靈活性。它可以用來把一組類別和函數連結起來,而且提供了一種借助於特權函數來存取私人資料的手段。

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

設計模式中的組合模式在JavaScript程式建構中的使用(進階篇)

詳細解讀在JavaScript中實作設計模式中的轉接器模式的方法(圖文教學)

JavaScript設計模式開發中組合模式的使用教學課程(進階篇)

#

以上是詳細解讀JavaScript設計模式開發中的橋接模式(進階篇)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java框架中設計模式與架構模式的區別 Java框架中設計模式與架構模式的區別 Jun 02, 2024 pm 12:59 PM

在Java框架中,設計模式和架構模式的區別在於:設計模式定義了在軟體設計中解決常見問題的抽象解決方案,專注於類別和物件之間的交互,例如工廠模式。架構模式定義了系統結構和模組之間的關係,關注系統元件的組織和交互,如分層架構。

Java設計模式之裝飾器模式剖析 Java設計模式之裝飾器模式剖析 May 09, 2024 pm 03:12 PM

裝飾器模式是一種結構型設計模式,允許動態添加物件功能,無需修改原始類別。它透過抽象組件、具體組件、抽象裝飾器和具體裝飾器的協作實現,可以靈活擴展類別功能,滿足變化的需求。範例中,將牛奶和摩卡裝飾器添加到Espresso,總價為2.29美元,展示了裝飾器模式在動態修改物件行為方面的強大功能。

PHP 設計模式實戰案例解析 PHP 設計模式實戰案例解析 May 08, 2024 am 08:09 AM

1.工廠模式:分離物件創建和業務邏輯,透過工廠類別建立指定類型的物件。 2.觀察者模式:允許主題物件通知觀察者物件其狀態更改,實現鬆散耦合和觀察者模式。

設計模式如何應對程式碼維護難題 設計模式如何應對程式碼維護難題 May 09, 2024 pm 12:45 PM

設計模式透過提供可重複使用和可擴展的解決方案來解決程式碼維護難題:觀察者模式:允許物件訂閱事件,並在事件發生時收到通知。工廠模式:提供了一種創建物件的集中式方式,而無需依賴特定類別。單例模式:確保一個類別只有一個實例,用於建立全域可存取的物件。

PHP設計模式:測試驅動開發實踐 PHP設計模式:測試驅動開發實踐 Jun 03, 2024 pm 02:14 PM

TDD用於編寫高品質PHP程式碼,步驟包括:編寫測試案例,描述預期功能並使其失敗。編寫程式碼,僅使測試案例通過,無需過度優化或詳細設計。測試案例通過後,優化和重構程式碼以提高可讀性、可維護性和可擴展性。

Java設計模式之適配器模式的妙用 Java設計模式之適配器模式的妙用 May 09, 2024 pm 12:54 PM

適配器模式是一種結構型設計模式,允許不相容物件協同工作,它將一個介面轉換為另一個,使物件能夠順利互動。物件適配器透過建立包含被適配器對象的適配器對象,並實現目標接口,實現適配器模式。在一個實戰案例中,透過適配器模式,客戶端(如MediaPlayer)可以播放高級格式的媒體(如VLC),儘管本身僅支援普通媒體格式(如MP3)。

Guice框架中設計模式的應用 Guice框架中設計模式的應用 Jun 02, 2024 pm 10:49 PM

Guice框架應用了多項設計模式,包括:單例模式:透過@Singleton註解確保類別只有一個實例。工廠方法模式:透過@Provides註解建立工廠方法,在依賴注入時取得物件實例。策略模式:將演算法封裝成不同策略類,透過@Named註解指定具體策略。

java框架中使用設計模式的優缺點有哪些? java框架中使用設計模式的優缺點有哪些? Jun 01, 2024 pm 02:13 PM

Java框架中使用設計模式的優點包括:程式碼可讀性、可維護性和可擴充性增強。缺點包括:過度使用導致複雜性、效能開銷以及學習曲線陡峭。實戰案例:代理模式用於延遲載入物件。明智地使用設計模式可充分利用其優勢並最小化缺點。

See all articles