Heim Web-Frontend js-Tutorial Vertiefendes Verständnis der JavaScript-Reihe (25): Detaillierte Erläuterung des Singleton-Musters von Entwurfsmustern_Grundkenntnisse

Vertiefendes Verständnis der JavaScript-Reihe (25): Detaillierte Erläuterung des Singleton-Musters von Entwurfsmustern_Grundkenntnisse

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

Einführung

Ab diesem Kapitel werden wir schrittweise die Implementierung verschiedener in JavaScript verwendeter Entwurfsmuster vorstellen. Hier werde ich nicht zu viel über die Theorie des Musters selbst vorstellen, sondern mich nur auf die Implementierung konzentrieren. OK, es hat offiziell begonnen.

In den Augen traditioneller Entwicklungsingenieure besteht die Implementierungsmethode darin, sicherzustellen, dass eine Klasse nur eine Instanz hat. Wenn sie vorhanden ist, wird sie direkt zurückgegeben , erstellen und zurückgeben. Dadurch wird sichergestellt, dass eine Klasse nur ein Instanzobjekt hat. In JavaScript fungiert ein Singleton als Namespace-Anbieter und stellt einen eindeutigen Zugriffspunkt auf das Objekt aus dem globalen Namespace bereit.

Text

In JavaScript gibt es viele Möglichkeiten, Singletons zu implementieren. Eine der einfachsten Möglichkeiten ist die Verwendung von Objektliteralen, die eine große Anzahl von Eigenschaften und Methoden enthalten können:

Code kopieren Der Code lautet wie folgt:

var mySingleton = {
Eigenschaft1: „etwas“,
Property2: „etwas anderes“,
Methode 1: Funktion () {
console.log('hello world');
}
};

Wenn Sie dieses Objekt später erweitern, können Sie Ihre eigenen privaten Mitglieder und Methoden hinzufügen und dann Schließungen verwenden, um diese Variablen- und Funktionsdeklarationen darin zu kapseln. Stellen Sie nur die öffentlichen Mitglieder und Methoden bereit, die Sie verfügbar machen möchten. Der Beispielcode lautet wie folgt:
Code kopieren Der Code lautet wie folgt:

var mySingleton = function () {

/* Hier private Variablen und Methoden deklarieren */
var privateVariable = 'etwas Privates';
Funktion showPrivate() {
console.log(privateVariable);
}

/* Öffentliche Variablen und Methoden (auf private Variablen und Methoden kann zugegriffen werden) */
Geben Sie {
zurück          publicMethod: function () {
              showPrivate();
},
publicVar: 'Die Öffentlichkeit kann das sehen!'
};
};

var single = mySingleton();
single.publicMethod(); // „Etwas Privates“ ausgeben
console.log(single.publicVar); // Ausgabe „Die Öffentlichkeit kann dies sehen!“

Der obige Code ist sehr gut, aber was ist, wenn wir ihn nur initialisieren möchten, wenn er verwendet wird? Um Ressourcen zu sparen, können wir diese Codes wie folgt in einem anderen Konstruktor initialisieren:

Code kopieren Der Code lautet wie folgt:

var Singleton = (function () {
var instanziiert;
Funktion init() {
/*Singleton-Code hier definieren*/
         return {
              publicMethod: function () {
console.log('hello world');
            },
             publicProperty: 'test'
        };
}

zurück {
         getInstance: function () {
                if (!instanziiert) {
                         instanziiert = init();
            }
             Rückgabe instanziiert;
}
};
})();

/*Öffentliche Methoden aufrufen, um Instanzen abzurufen:*/
Singleton.getInstance().publicMethod();

Wir wissen jetzt, wie man einen Singleton implementiert, aber in welchen Szenarien wird ein Singleton am besten verwendet? Tatsächlich werden Singletons im Allgemeinen verwendet, um verschiedene Kommunikationsmodi zwischen Systemen zu koordinieren. Der folgende Code ist eine bewährte Methode für einen Singleton:

Code kopieren Der Code lautet wie folgt:

var SingletonTester = (function () {

//Parameter: eine Reihe von Parametern, die an den Singleton
übergeben werden Funktion Singleton(args) {

//Setzen Sie die Variable args auf die empfangenen Parameter oder leer (falls nicht angegeben)
var args = args ||. {};
//Legen Sie den Namensparameter fest
This.name = 'SingletonTester';
//Setze den Wert von pointX
This.pointX = args.pointX ||. 6; //Erhalten Sie es aus den empfangenen Parametern oder setzen Sie es auf den Standardwert
//Setze den Wert von pointY
This.pointY = args.pointY || 10;

}

//Instanzcontainer
var-Instanz;

var _static = {
Name: 'SingletonTester',

//Methode zum Abrufen der Instanz
//Singleton-Instanz zurückgeben
         getInstance: Funktion (Argumente) {
If (Instanz === undefiniert) {
                    Instanz = new Singleton(args);
            }
             Instanz zurückgeben;
}
};
Geben Sie _static;
zurück })();

var singletonTest = SingletonTester.getInstance({ pointX: 5 });
console.log(singletonTest.pointX); // Ausgabe 5

Andere Implementierungsmethoden

Methode 1:

Code kopieren Der Code lautet wie folgt:

Funktion Universe() {

// Bestimmen Sie, ob eine Instanz vorhanden ist
If (typeof Universe.instance === 'object') {
         return Universe.instance;
}

// Andere Inhalte
This.start_time = 0;
This.bang = "Big";

// Cache
Universe.instance = this;

// Gibt dies implizit zurück
}

//Test
var uni = neues Universum();
var uni2 = neues Universum();
console.log(uni === uni2); // true

Methode 2:

Code kopieren Der Code lautet wie folgt:

Funktion Universe() {

// zwischengespeicherte Instanz
var-Instanz = this;

// Andere Inhalte
This.start_time = 0;
This.bang = "Big";

// Konstruktor überschreiben
Universum = Funktion () {
         Instanz zurückgeben;
};
}

//Test
var uni = neues Universum();
var uni2 = neues Universum();
uni.bang = "123";
console.log(uni === uni2); // true
console.log(uni2.bang); // 123

Methode 3:

Code kopieren Der Code lautet wie folgt:

Funktion Universe() {

// Cache-Instanz
var-Instanz;

// Rekonstruktorfunktion
Universum = Funktion Universe() {
         Instanz zurückgeben;
};

// Nachbearbeitung der Prototypeneigenschaften
Universe.prototype = this;

// Beispiel
Instanz = neues Universum();

// Konstruktorzeiger zurücksetzen
Instance.constructor = Universe;

// Weitere Funktionen
Instance.start_time = 0;
Instance.bang = "Big";

Instanz zurückgeben;
}


// Test
var uni = neues Universum();
var uni2 = neues Universum();
console.log(uni === uni2); // true

//Prototypattribute hinzufügen
Universe.prototype.nothing = true;

var uni = new Universe();

Universe.prototype.everything = true;

var uni2 = new Universe();

console.log(uni.nothing); // true
console.log(uni2.nothing); // true
console.log(uni.everything); // true
console.log(uni2.everything); // true
console.log(uni.constructor === Universe); // true

Methode 4:

Code kopieren Der Code lautet wie folgt:

var Universum;

(Funktion () {

var-Instanz;

Universum = Funktion Universe() {

if (instance) {
             Instanz zurückgeben;
}

Instanz = this;

// Andere Inhalte
This.start_time = 0;
This.bang = "Big";
};
} ());

//Testcode
var a = neues Universum();
var b = neues Universum();
alarm(a === b); // true
a.bang = "123";
alarm(b.bang); // 123

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