Heim > Web-Frontend > js-Tutorial > JavaScript-Entwurfsmuster Serie 5: Adaptermuster

JavaScript-Entwurfsmuster Serie 5: Adaptermuster

不言
Freigeben: 2018-04-02 14:05:44
Original
1180 Leute haben es durchsucht

Dieser Artikel stellt Ihnen die fünfte Reihe von JavaScript-Entwurfsmustern vor: Interessierte Freunde können einen Blick darauf werfen

Was ist das Adaptermuster?

Das sogenannte Adaptermuster Es dient dazu, eine neue Schnittstelle zu verwenden, um die vorhandene Schnittstelle zu umschließen und die Nichtübereinstimmung zwischen der Klasse und der API zu beheben. Objekte, die dieses Muster verwenden, werden auch Wrapper genannt.
Zum Beispiel haben wir eine Schnittstelle:

function api (x1, x2, x3) {
  console.log(x1 + x2 + x3);  // 用console.log来模拟接口的相关操作
}
Nach dem Login kopieren

Dann haben wir Objektdaten:

var obj = {
  a: '我',
  b: '很',
  c: '帅'
}
Nach dem Login kopieren

Wir können feststellen, dass unsere Daten nicht mit den Parametern der Schnittstelle übereinstimmen , Es ist nicht möglich, obj direkt einzugeben, um die API aufzurufen.
Was sollen wir jetzt tun? Wir können eine Adapterfunktion definieren:

function adapter (o) {
  // 通过适配器函数来调用目的api
  api(o.a, o.b, o.c);
} 

adapter(obj);
// 我很帅
Nach dem Login kopieren

Auf diese Weise können wir über die Adapterfunktion adapter() direkt obj übergeben, um die API aufzurufen, und das Problem der Nichtübereinstimmung zwischen der Klasse und der API wird behoben gelöst.


Zusammenfassung

Das Adaptermuster besteht darin, die vorhandene Schnittstelle mit einer neuen Schnittstelle zu umschließen, um die Nichtübereinstimmung zwischen der Klasse und der API zu beheben. Objekte, die dieses Muster verwenden, werden auch Wrapper genannt.
Anwendbare Situationen

  1. Verwenden Sie ein vorhandenes Objekt, dessen Methoden- oder Eigenschaftenschnittstelle jedoch nicht unseren Anforderungen entspricht.

  2. Möchten Sie ein wiederverwendbares Objekt erstellen, das mit anderen nicht verwandten oder unsichtbaren Objekten zusammenarbeiten kann

  3. Möchten Sie Die verwendeten Objekte sind bereits vorhanden, aber prototypische Vererbung kann nicht auf jede einzelne angewendet werden, um sie an ihre Schnittstelle anzupassen. Ein Objektadapter kann die Schnittstellenmethoden oder Eigenschaften seines übergeordneten Objekts anpassen.

Unterschiede zu anderen Modi

  1. Obwohl Adapter und Brücken ähnlich sind, ist der Ausgangspunkt der Überbrückung unterschiedlich Der Zweck besteht darin, den Schnittstellenteil vom Implementierungsteil zu trennen, damit sie einfacher und unabhängiger geändert werden können.

  2. Das Dekoratormuster verbessert die Funktionalität des Objekts, ohne seine Schnittstelle zu ändern, sodass es dem Programm eine bessere Transparenz bietet als der Adapter.

  3. Der Proxy-Modus definiert einen Proxy für eine andere Schnittstelle, ohne deren Schnittstelle zu ändern.

  4. Der Fassadenmodus dient der Vereinfachung einer Benutzeroberfläche und bietet keine zusätzlichen Optionen.

  5. Der Adapter wandelt eine Schnittstelle in eine andere Schnittstelle um und filtert weder bestimmte Funktionen heraus noch vereinfacht er die Schnittstelle.

Verwandte Empfehlungen:

JavaScript-Designmuster Serie Eins: Factory-Muster

JavaScript-Designmuster Serie Drei: Builder-Modus

Das obige ist der detaillierte Inhalt vonJavaScript-Entwurfsmuster Serie 5: Adaptermuster. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage