91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Javascript中如何實現橋接模式

發布時間:2022-05-07 13:41:17 來源:億速云 閱讀:191 作者:iii 欄目:大數據

這篇文章主要講解了“Javascript中如何實現橋接模式”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Javascript中如何實現橋接模式”吧!

基本理論

橋接模式定義:將抽象部分與它的實現部分分離,使它們都可以獨立地變化。
橋接模式主要有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"); }

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

1 var message = new MessageDialog(new LinerAnimation());
2 message.show();
3 var error = new ErrorDialog(new EaseAnimation());
4 error.show();

感謝各位的閱讀,以上就是“Javascript中如何實現橋接模式”的內容了,經過本文的學習后,相信大家對Javascript中如何實現橋接模式這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

AI

金乡县| 武隆县| 沭阳县| 长岛县| 乳源| 元阳县| 百色市| 张家港市| 河池市| 灵丘县| 东山县| 通渭县| 乌拉特中旗| 山阳县| 怀仁县| 故城县| 蕲春县| 鹿邑县| 连城县| 冷水江市| 治县。| 黑水县| 双柏县| 班戈县| 连州市| 庆安县| 博客| 开远市| 新和县| 临武县| 临沭县| 连南| 德惠市| 长顺县| 兴安盟| 中卫市| 潮州市| 永德县| 利川市| 噶尔县| 深水埗区|