Heim > Web-Frontend > js-Tutorial > Hauptteil

JavaScript: Ähnlichkeiten und Unterschiede zwischen einer neuen Funktion und dem direkten Aufruf der Funktion

高洛峰
Freigeben: 2016-11-25 14:29:35
Original
968 Leute haben es durchsucht

Vielleicht sind viele Leute damit nicht einverstanden, das neue Schlüsselwort vor einer Funktion hinzuzufügen, bedeutet doch, ein Objekt zu instanziieren, oder? Aber so einfach ist es offensichtlich nicht:


function Test() {
This.name = 'Test';
return function() { return true }
}

var test = new Test(); // Was ist der Test hier?
Ist es ein Testobjekt? falsch! Hier ist test eine Funktion - function() { return true }, die in Test zurückgegeben wird. Zu diesem Zeitpunkt ist new Test() äquivalent zu Test(), nicht gleich. Wenn Sie new Test() == Test() verwenden, um festzustellen, ob die beiden gleich sind, wird false zurückgegeben , weil Javascript für den Objektvergleich mit der Funktion auf Referenz basiert.

Um den Unterschied zwischen den beiden in der obigen Situation klarer zu unterscheiden, schauen Sie sich bitte weiterhin den folgenden Code an:

function Test() {
 this.name = ' Test';
return 'Test'; Haha, verwirrt dich das erste Beispiel? Tatsächlich ist newT zu diesem Zeitpunkt ein Testobjekt – es verfügt über eine Eigenschaft namens name, deren Wert die Zeichenfolge Test ist.

Aus den beiden oben genannten Codeteilen können wir eine Vermutung anstellen. Wenn der Rückgabewert der Funktion ein herkömmlicher Werttyp ist (Zahl, Zeichenfolge, Boolescher Wert), gibt die neue Funktion ein Instanzobjekt der Funktion zurück. und wenn die Funktion einen Referenztyp (Objekt, Array, Funktion) zurückgibt, entspricht die neue Funktion dem Ergebnis des direkten Aufrufs der Funktion. Dies kann durch Testen bestätigt werden, indem in der Testfunktion verschiedene Arten von Werten zurückgegeben werden. ​

Es ist eigentlich sehr wichtig, diesen Punkt zu unterscheiden, zumindest wenn man sich den Code einer objektorientierten Framework-Klassenbibliothek ansieht, wird es weniger Verwirrung geben.

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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!