Funktionsausdrücke mit „neuem“ Schlüsselwort: Enthüllung der statischen Natur
In JavaScript das Verhalten von Funktionsausdrücken mit dem „neuen“ verstehen Schlüsselwort ist entscheidend. Betrachten Sie den folgenden Code:
var gameData = new function () { // Function expressions require no constructor this.storageAvailable = function () { ... }; };
Es ist wichtig zu beachten, dass das Schlüsselwort „new“ in diesem Fall keine Instanziierung impliziert oder die Erstellung mehrerer Instanzen ermöglicht. Stattdessen führt es einfach den Funktionsausdruck aus und weist das resultierende anonyme Objekt der Variablen „gameData“ zu.
Das Missverständnis des statischen Verhaltens
Das Konzept des statischen Verhaltens in C# kann zu der falschen Vorstellung führen, dass sich der Funktionsausdruck in JavaScript auch statisch verhält. Dies ist jedoch ungenau. Das Schlüsselwort „new“ verhindert hier nicht die Erstellung eines zweiten Objekts:
var gameData2 = new (gameData.constructor)(); // Reinstantiation is possible
Zusätzlich verfügt der Funktionsausdruck noch über eine Konstruktoreigenschaft, die auf die anonyme Funktion verweist, auf die mit „gameData.constructor“ zugegriffen werden kann '. Dies macht den Zweck einer echten statischen Klasse zunichte.
Alternativen zum statischen Verhalten
Wenn die Absicht darin besteht, ein einzelnes, nicht instanziierbares Objekt zu erstellen, gibt es geeignetere Alternativen zur Verwendung von Funktionsausdrücken mit „new“:
Zusammenfassend lässt sich sagen, dass Funktionsausdrücke mit „neuen“ Schlüsselwörtern in JavaScript kein statisches Verhalten zeigen, wie es sein könnte mehrfach instanziiert und verfügen über eine öffentliche Konstruktor-Eigenschaft, auf die über „gameData.constructor“ zugegriffen werden kann. Für echtes statisches Verhalten sollten Sie alternative Ansätze wie Objektliterale, offenbarende Modulmuster oder das Singleton-Muster in Betracht ziehen.
Das obige ist der detaillierte Inhalt vonErzeugt „neu' mit JavaScript-Funktionsausdrücken statisches Verhalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!