Heim Web-Frontend js-Tutorial Beispiel für JavaScript-Designmuster-Singleton-Muster_Javascript-Kenntnisse

Beispiel für JavaScript-Designmuster-Singleton-Muster_Javascript-Kenntnisse

May 16, 2016 pm 04:35 PM
javascript 单例模式 设计模式

Peter Seibel, Autor von „Practical Common Lisp“, sagte einmal: Wenn man ein Muster braucht, stimmt etwas nicht. Das Problem, auf das er sich bezieht, besteht darin, dass er aufgrund der inhärenten Mängel der Sprache eine allgemeine Lösung finden und zusammenfassen muss.

Ob es sich um eine schwach typisierte oder stark typisierte Sprache, eine statische oder dynamische Sprache, eine imperative oder deklarative Sprache handelt, jede Sprache hat ihre inhärenten Vor- und Nachteile. Ein jamaikanischer Athlet hat einige Vorteile im Sprinten und sogar im Boxen, aber es mangelt ihm an Yoga.

Hexenmeister und Schattenpriester können leicht eine hervorragende Unterstützung sein, aber ein feindlicher Magier, der mit Macon auf dem Rücken über die Karte fliegt, wird etwas unbeholfen sein. Beim Wechsel zu einem Programm ist die Implementierung von Dekoratoren in statischen Sprachen möglicherweise sehr aufwändig. Da js jedoch jederzeit Methoden auf Objekte werfen kann, ist das Dekoratormuster in js unbrauchbar geworden.

Es gibt relativ wenige Bücher, die über JavaScript-Designmuster sprechen. „Pro JavaScript Design Patterns“ ist ein Klassiker, aber die darin enthaltenen Beispiele sind ziemlich ausführlich, daher habe ich sie mit den Codes kombiniert, die ich bei der Arbeit geschrieben habe zusammenfassen. Sollte es Abweichungen in meinem Verständnis geben, können Sie mich jederzeit korrigieren.

1. Singleton-Modus

Die Definition des Singleton-Musters besteht darin, eine eindeutige Instanz einer Klasse zu erzeugen, aber js selbst ist eine „klassenlose“ Sprache. Viele Artikel, die sich mit js-Entwurfsmustern befassen, verwenden {} als Singleton, was kaum Sinn ergibt. Da es viele Möglichkeiten gibt, Objekte in js zu generieren, werfen wir einen Blick auf einen anderen aussagekräftigeren Singleton.

Es gibt eine so häufige Anforderung, dass beim Klicken auf eine Schaltfläche eine Maskenebene auf der Seite angezeigt werden muss. Zum Beispiel, wenn Sie klicken, um sich auf web.qq.com anzumelden.

Dieser Code zum Generieren einer grauen Hintergrundmaskenebene ist sehr einfach zu schreiben.

Code kopieren Der Code lautet wie folgt:

var createMask = function(){
return document,body.appendChild( document.createElement(div) );
}
$( 'button' ).click( function(){
Var mask = createMask();
mask.show();
})

Das Problem besteht darin, dass diese Maskenebene global einzigartig ist, sodass bei jedem Aufruf von createMask ein neues Div erstellt wird. Sie können es zwar entfernen, wenn Sie die Maskenebene ausblenden, aber dies ist offensichtlich unvernünftig

Sehen wir uns die zweite Option an. Erstellen Sie dieses Div am Anfang der Seite. Verwenden Sie dann eine Variable, um darauf zu verweisen.

Code kopieren Der Code lautet wie folgt:
var mask = document.body.appendChild( document.createElement( ”div' ) );
$( ”button' ).click( function(){
mask.show();
} )

Auf diese Weise wird nur ein Maskenebenen-Div auf der Seite erstellt, aber es entsteht ein weiteres Problem. Möglicherweise werden wir diese Maskenebene nie benötigen, wodurch ein weiteres Div verschwendet wird, und jede Operation auf dem DOM-Knoten wird durchgeführt sehr geizig.

Was wäre, wenn Sie eine Variable verwenden könnten, um festzustellen, ob das Div erstellt wurde?

Code kopieren Der Code lautet wie folgt:
var mask;
var createMask = function(){
if (mask) return mask;
sonst{
mask = document,body.appendChild( document.createElement(div) );
Rückgabemaske;
}
}

Es sieht gut aus, hier haben wir tatsächlich eine Funktion fertiggestellt, die ein einzelnes Spaltenobjekt generiert. Schauen wir uns genauer an, was an diesem Code falsch ist.

Zuallererst hat diese Funktion bestimmte Nebenwirkungen. In einem Mehrpersonen-Kollaborationsprojekt ist createMask eine unsichere Funktion Eine Maske ist nicht unbedingt notwendig. Lasst es uns noch einmal verbessern.

Code kopieren Der Code lautet wie folgt:
var createMask = function(){
var mask;
Rückgabefunktion(){
Rückgabemaske ||. ( mask = document.body.appendChild( document.createElement('div') )
}
}()

Ein einfacher Verschluss wird verwendet, um die Variablenmaske einzuschließen, zumindest für die createMask-Funktion ist sie geschlossen.

Sie sehen das vielleicht und denken, dass das Singleton-Muster zu einfach ist. Auch wenn Sie dem Konzept der Designmuster nie Beachtung geschenkt haben, verwenden Sie einige davon immer noch unwissentlich Code. Genau wie vor vielen Jahren, als ich verstand, was der Kinderwagen des alten Mannes war, stellte sich heraus, dass dies der Kinderwagen des alten Mannes war

Bei den 23 Entwurfsmustern in GOF handelt es sich ebenfalls um Muster, die schon lange existieren und immer wieder in der Softwareentwicklung verwendet werden. Wenn dem Programmierer nicht klar ist, dass er bestimmte Muster verwendet hat, kann es sein, dass ihm beim nächsten Mal ein passenderes Design entgeht (Dies Die Passage stammt aus „Yukihiro Matsumotos Programmierwelt“).

Zurück zum Thema: Der vorherige Singleton kann nur zum Erstellen von Maskenebenen verwendet werden. Kann ich einen universellen Singleton finden? 🎜>

Funktionen in js sind vom ersten Typ, was bedeutet, dass Funktionen auch als Parameter übergeben werden können.

var singleton = function( fn ){
var result;
Rückgabefunktion(){
Rückgabeergebnis ||. ( result = fn .apply( this, arguments ) );
}
}
var createMask = singleton( function(){
return document.body.appendChild( document.createElement('div') );
})


Verwenden Sie eine Variable, um den ersten Rückgabewert zu speichern. Bei nachfolgenden Aufrufen wird die Variable zuerst zurückgegeben. Der Code, der die Maskenebene tatsächlich erstellt, wird über die Rückruffunktion übergeben Wrapper. Über den Bridge-Modus werde ich etwas später sprechen Die Singleton-Funktion ist jedoch nicht perfekt, um die Referenz des div zu speichern. Leider reichen die funktionalen Eigenschaften von js nicht aus, um Deklarationen und Anweisungen vollständig zu eliminieren.

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Der Unterschied zwischen Entwurfsmustern und Architekturmustern im Java-Framework Der Unterschied zwischen Entwurfsmustern und Architekturmustern im Java-Framework Jun 02, 2024 pm 12:59 PM

Im Java-Framework besteht der Unterschied zwischen Entwurfsmustern und Architekturmustern darin, dass Entwurfsmuster abstrakte Lösungen für häufige Probleme beim Softwaredesign definieren und sich dabei auf die Interaktion zwischen Klassen und Objekten konzentrieren, beispielsweise Fabrikmuster. Architekturmuster definieren die Beziehung zwischen Systemstrukturen und Modulen und konzentrieren sich auf die Organisation und Interaktion von Systemkomponenten, wie z. B. eine geschichtete Architektur.

Analyse des Decorator-Musters in Java-Entwurfsmustern Analyse des Decorator-Musters in Java-Entwurfsmustern May 09, 2024 pm 03:12 PM

Das Dekoratormuster ist ein strukturelles Entwurfsmuster, das das dynamische Hinzufügen von Objektfunktionen ermöglicht, ohne die ursprüngliche Klasse zu ändern. Es wird durch die Zusammenarbeit von abstrakten Komponenten, konkreten Komponenten, abstrakten Dekoratoren und konkreten Dekoratoren implementiert und kann Klassenfunktionen flexibel erweitern, um sich ändernden Anforderungen gerecht zu werden. In diesem Beispiel werden Milch- und Mokka-Dekoratoren zu Espresso für einen Gesamtpreis von 2,29 $ hinzugefügt, was die Leistungsfähigkeit des Dekoratormusters bei der dynamischen Änderung des Verhaltens von Objekten demonstriert.

Praktische Fallanalyse des PHP-Entwurfsmusters Praktische Fallanalyse des PHP-Entwurfsmusters May 08, 2024 am 08:09 AM

1. Factory-Muster: Trennen Sie Objekterstellung und Geschäftslogik und erstellen Sie Objekte bestimmter Typen über Factory-Klassen. 2. Beobachtermuster: Ermöglicht Subjektobjekten, Beobachterobjekte über ihre Zustandsänderungen zu benachrichtigen, wodurch eine lose Kopplung und ein Beobachtermuster erreicht werden.

Wie Entwurfsmuster mit Herausforderungen bei der Codewartung umgehen Wie Entwurfsmuster mit Herausforderungen bei der Codewartung umgehen May 09, 2024 pm 12:45 PM

Entwurfsmuster lösen Herausforderungen bei der Codewartung, indem sie wiederverwendbare und erweiterbare Lösungen bereitstellen: Beobachtermuster: Ermöglicht Objekten, Ereignisse zu abonnieren und Benachrichtigungen zu erhalten, wenn sie auftreten. Factory-Muster: Bietet eine zentralisierte Möglichkeit, Objekte zu erstellen, ohne auf konkrete Klassen angewiesen zu sein. Singleton-Muster: stellt sicher, dass eine Klasse nur eine Instanz hat, die zum Erstellen global zugänglicher Objekte verwendet wird.

Die wunderbare Verwendung des Adaptermusters in Java-Entwurfsmustern Die wunderbare Verwendung des Adaptermusters in Java-Entwurfsmustern May 09, 2024 pm 12:54 PM

Das Adaptermuster ist ein strukturelles Entwurfsmuster, das die Zusammenarbeit inkompatibler Objekte ermöglicht. Es wandelt eine Schnittstelle in eine andere um, sodass die Objekte reibungslos interagieren können. Der Objektadapter implementiert das Adaptermuster, indem er ein Adapterobjekt erstellt, das das angepasste Objekt enthält, und die Zielschnittstelle implementiert. In einem praktischen Fall kann der Client (z. B. MediaPlayer) über den Adaptermodus Medien im erweiterten Format (z. B. VLC) abspielen, obwohl er selbst nur normale Medienformate (z. B. MP3) unterstützt.

PHP-Entwurfsmuster: Testgetriebene Entwicklung in der Praxis PHP-Entwurfsmuster: Testgetriebene Entwicklung in der Praxis Jun 03, 2024 pm 02:14 PM

TDD wird verwendet, um hochwertigen PHP-Code zu schreiben. Die Schritte umfassen: Testfälle schreiben, die erwartete Funktionalität beschreiben und sie zum Scheitern bringen. Schreiben Sie Code so, dass nur die Testfälle ohne übermäßige Optimierung oder detailliertes Design erfolgreich sind. Nachdem die Testfälle bestanden wurden, optimieren und überarbeiten Sie den Code, um die Lesbarkeit, Wartbarkeit und Skalierbarkeit zu verbessern.

Anwendung von Designmustern im Guice-Framework Anwendung von Designmustern im Guice-Framework Jun 02, 2024 pm 10:49 PM

Das Guice-Framework wendet eine Reihe von Entwurfsmustern an, darunter: Singleton-Muster: Durch die @Singleton-Annotation wird sichergestellt, dass eine Klasse nur eine Instanz hat. Factory-Methodenmuster: Erstellen Sie eine Factory-Methode über die Annotation @Provides und rufen Sie die Objektinstanz während der Abhängigkeitsinjektion ab. Strategiemodus: Kapseln Sie den Algorithmus in verschiedene Strategieklassen und geben Sie die spezifische Strategie über die Annotation @Named an.

Was sind die Vor- und Nachteile der Verwendung von Entwurfsmustern im Java-Framework? Was sind die Vor- und Nachteile der Verwendung von Entwurfsmustern im Java-Framework? Jun 01, 2024 pm 02:13 PM

Zu den Vorteilen der Verwendung von Entwurfsmustern in Java-Frameworks gehören: verbesserte Lesbarkeit, Wartbarkeit und Skalierbarkeit des Codes. Zu den Nachteilen gehören Komplexität, Leistungsaufwand und eine steile Lernkurve aufgrund übermäßiger Nutzung. Praktischer Fall: Der Proxy-Modus wird zum verzögerten Laden von Objekten verwendet. Setzen Sie Entwurfsmuster mit Bedacht ein, um ihre Vorteile zu nutzen und ihre Nachteile zu minimieren.

See all articles