ブリッジ モードは、イベント コールバック関数とインターフェイスの間のブリッジに加えて、パブリック API コードとプライベート実装コードを接続するためにも使用できます。JavaScript 設計の開発について詳しく説明します。ブリッジ パターンは、
ブリッジ パターンを使用して抽象部分を実装部分から分離し、両方が独立して変更され、調和して動作できるようにします。抽象部分と実装部分の両方は、相互に影響を与えることなく独立して変更できるため、コードの結合が減少し、コードのスケーラビリティが向上します。
GoF の定義によれば、ブリッジ パターンの役割は、「抽象化を実装から分離して、独立して変更できるようにする」ことです。このパターンは、JavaScript で一般的なイベント駆動型プログラミングに非常に役立ちます。
ブリッジ モードの最も一般的で実用的なアプリケーションの 1 つは、イベント リスナー コールバック関数です。例: イベント リスナーは、イベント処理ステートメントをコールバック関数にカプセル化し、実装ではなくインターフェイスを通じてプログラミングを実行します。
基本理論
ブリッジパターン定義: 抽象部分とその実装部分を分離し、両方が独立して変更できるようにします。
ブリッジモードは主に4つの役割で構成されます:
(1) 抽象クラス
(2) 拡張抽象クラス
(3) 実装クラスインターフェース
(4) 具象実装クラス
JavaScript言語の特性に合わせて簡略化していますそれぞれの役割:
(1) 拡張抽象クラス
(2) 具体的な実装クラス
ブリッジモードを理解するには?次にブリッジパターンの実装例を示します
ブリッジパターンの考え方を理解するには、抽象部分と実装部分を分離するという考え方を理解することが重要です。例で説明しましょう
最も単純なブリッジ モード実際、私たちが最も頻繁に使用する jQuery の各関数は、次のようにその実装をシミュレートします: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; })この例では、各関数 arr 配列は、この例は非常に一般的ですが、典型的なブリッジ モードが含まれています。
この例では、抽象部は前述の拡張抽象クラスである each 関数、実装部は具象実装クラスである fn です。抽象部分と実装部分は独立して変更できます。この例は単純ですが、典型的なブリッジ モード アプリケーションです。
プラグイン開発におけるブリッジ モード
ブリッジ モードに適用できるシナリオはコンポーネント開発です。私たちは通常、さまざまな状況に適応するようにコンポーネントを開発しますが、コンポーネントはそれに応じてさまざまな次元で変化します。ここでブリッジ パターンを適用して、その抽象化と実装を分離し、コンポーネントのスケーラビリティを高めることができます。 ポップアップウィンドウプラグインを開発するとします。ポップアップウィンドウには通常のメッセージリマインダー、エラーリマインダーなどの種類があり、それぞれ表示方法が異なります。これは典型的な多次元変化シナリオです。まず、通常のメッセージ ポップアップ ウィンドウとエラー メッセージ ポップアップ ウィンドウの 2 つのクラスを定義します。
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(); }
これら 2 つのクラスは、前述の抽象部分、つまり拡張抽象クラスです。両方ともメンバー アニメーションを含んでいます。
2 つのポップアップ ウィンドウは show メソッドによって表示されますが、表示されるアニメーション効果は異なります。次のように 2 つの表示効果クラスを定義します。
function LinerAnimation() { } LinerAnimation.prototype.show = function () { console.log("it is liner"); } function EaseAnimation() { } EaseAnimation.prototype.show = function () { console.log("it is ease"); }
これら 2 つのクラスは、特定の表示効果を実装する特定の実装クラスです。では、それをどのように呼ぶのでしょうか?
var message = new MessageDialog(new LinerAnimation()); message.show(); var error = new ErrorDialog(new EaseAnimation()); error.show();アニメーション効果を追加したい場合は、別の効果クラスを定義してそれを渡すことができます。
まとめ
ブリッジパターンを学習する鍵は、抽象部分と実装部分の分離を理解し、その 2 つが形式に制限されずに独立して変更できるようにすることです。 JS プラグインの柔軟な変更と適用可能なシナリオの変更は、このモードの実装に非常に適しています。ブリッジ パターンの使用で最も重要なことは、システム内の変化のさまざまな側面を特定することです。
(1) ブリッジ モードの利点: 抽象化と実装を分離し、ソフトウェアの各コンポーネントを個別に管理するのに役立ちます。
(2) ブリッジ モードの欠点: ブリッジ要素が使用されるたびに関数呼び出しが追加され、アプリケーションのパフォーマンスに悪影響を及ぼします。システムの複雑さの増加。ブリッジ関数を使用して 2 つの関数を接続し、一方の関数がブリッジ関数の外部から呼び出されない場合、現時点ではブリッジ関数は必要ありません。
ブリッジ パターンは、「抽象化と実装を分離して、独立して変更できるようにします。」コードのモジュール性を促進し、よりクリーンな実装を可能にし、抽象化の柔軟性を高めます。これは、クラスと関数のグループを接続するために使用でき、特権関数を利用してプライベート データにアクセスする手段を提供します。 上記は私があなたのためにまとめたものです。
JavaScriptプログラム構築におけるデザインパターンにおける組み合わせパターンの使い方(上級編)
JavaScriptにおけるデザインパターンにおけるアダプターパターンの実装方法の詳細な解釈(グラフィックチュートリアル)
JavaScript デザインパターン開発における組み合わせパターンの使用に関するチュートリアル (上級)
以上がJavaScript デザインパターン開発におけるブリッジパターンの詳細な解釈 (上級)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









