Heim > Web-Frontend > js-Tutorial > Mehrere Möglichkeiten zum Erstellen von Objekten in Js

Mehrere Möglichkeiten zum Erstellen von Objekten in Js

大家讲道理
Freigeben: 2017-04-11 14:05:21
Original
1470 Leute haben es durchsucht

Erster Modus: Werksmodus

Anweisungen:
1. In der -FunktionObjekt in 🎜> und definieren Sie verschiedene Attribute des Objekts. Obwohl Attribute Methoden sein können, wird empfohlen, Attribute zu definieren, deren Attribute Methoden außerhalb der Funktion sind, um Wiederholungen zu vermeiden Diese Methode 2. Wenn sich
auf das -Objekt bezieht, wird var x = new Parent() verwendet, da letzteres viele Probleme verursachen kann (Ersteres ist auch zu einer klassischen Factory-Methode geworden, und letzteres wird als Hybrid-Factory-Methode bezeichnet. Es wird nicht empfohlen, die neue Methode zu verwenden, um das Objekt 3 zurückzugeben 🎜>4. Nein. Diese Art der
Erstellung von Objekten
wird empfohlen, sollte aber verstanden werden. Nachteile: ①Der Objekttyp kann nicht bestimmt werden (da es sich bei allen um

Objekte

handelt).  ② Es besteht keine Verbindung zwischen mehreren erstellten Objekten.

Zweiter Modus:

Konstrukteur Weg

Erklärung:

1 Im Vergleich zur Factory-Methode erfordert die Verwendung der Konstruktormethode zum Erstellen von Objekten keine Neuerstellung der erstellten Objekte innerhalb der Funktion, sondern verwendet diese als Referenz, und die Funktion muss nicht explizit

zurückgeben
2. Dasselbe wieDasselbe wie das Fabrikmuster
, obwohl der Wert des Attributs eine Methode sein kann, wird empfohlen, die Methode außerhalb der Funktion zu definieren3 Ebenso wird dies nicht empfohlen Sie können auf diese Weise Objekte erstellen, aber Sie müssen es trotzdem verstehen.
Nachteile: ① Mehrere Instanzen werden wiederholt erstellt und können nicht geteilt werden.

  ② Mehrere Instanzen sind keine Instanzen derselben Funktion.

Der dritte Modus:

Prototypmodus

Erklärung:

Da stimmt etwas nicht in der Funktion Attribute definieren

2. Verwenden Sie Prototypattribute, um Attribute zu definieren
3. Ebenso wird nicht empfohlen, Objekte auf diese Weise zu erstellen

Nachteile: ① Parameter und Attributwerte können nicht übergeben werden ​​kann nicht initialisiert werden.

  ②Wenn Sie den Wert einer Instanz ändern, wenn diese einen Referenztypwert enthält, wird er in allen Instanzen widergespiegelt.

Der vierte Modus: gemischte

Konstruktor- Funktion, Prototypmethode (empfohlen)

Anweisungen:

1. Dieses Muster bezieht sich auf das Mischen und Anpassen der Konstruktormethode und der Prototypmethode

2. Definieren Sie alle Attribute, die keine Methoden in Funktionen sind (Konstruktormethode)

Setzen Sie alle Attributwerte auf Die Attribute der Methode werden außerhalb der Funktion mithilfe des Prototyps (Prototypmethode) definiert
3. Es wird empfohlen, Objekte auf diese Weise zu erstellen

Vorteile: Konstruktoren teilen Instanzattribute, Prototypen teilen Methoden und Attribute, die Sie teilen möchten . Zur Initialisierung von Attributwerten können Parameter übergeben werden.

Der fünfte Modus: dynamische Prototypenmethode

Erklärung: 1 Die dynamische Prototypenmethode kann als gemischter Konstruktor verstanden werden. Prototyp Ein Sonderfall der Methode
2. In diesem Modus werden die Attribute der Methode direkt in der Funktion definiert, aber weil

ist dies beim Erstellen einer Instanz gewährleistet des Objekts werden die Attribute der Methode nicht wiederholt erstellt

3. Es wird empfohlen, diesen Modus zu verwenden.


Anhang: Detaillierte Erläuterung verschiedener Möglichkeiten zum Erstellen von Objekten in

JS

 

Das obige ist der detaillierte Inhalt vonMehrere Möglichkeiten zum Erstellen von Objekten in Js. 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