Deklaration und Auswertung von JavaScript-Funktionen
Hintergrund:
In JavaScript können Funktionen sein mithilfe von Ausdrücken deklariert oder erstellt werden. Funktionsdeklarationen erfolgen während der Kompilierungsphase, während Funktionsausdrücke während der Ausführungsphase ausgewertet werden. Das Verständnis dieser Unterscheidung ist entscheidend für das Verständnis des Verhaltens von JavaScript-Code.
Die Frage:
Warum schlägt das erste Beispiel im folgenden Codeblock fehl, während die übrigen Beispiele erfolgreich ausführen?
<code class="javascript">// 1 - does not work (function() { setTimeout(someFunction1, 10); var someFunction1 = function() { alert('here1'); }; })(); // ... other examples</code>
Die Antwort:
Das Scheitern des ersten Beispiels ist nicht auf ein Bereichs- oder Abschlussproblem zurückzuführen, sondern eher auf ein Missverständnis zwischen Deklarationen und Ausdrücken .
Funktionsdeklarationen vs. Ausdrücke:
Phase 1: Kompilierung
Während der Kompilierung verarbeitet der Compiler Funktionsdeklarationen und erstellt Variablen für die Funktionen. Im ersten Beispiel wird die Variable someFunction1 erstellt, bleibt jedoch undefiniert, da ihr Wert (der Funktionskörper) später ausgewertet wird.
Phase 2: Ausführung
Beispiel 1:
Zur Laufzeit trifft der Interpreter auf setTimeout(someFunction1, 10) und versucht, eine undefinierte someFunction1 an setTimeout zu übergeben.
Beispiel 2:
Im Gegensatz dazu ist die Funktion someFunction2() eine Deklaration, die die Funktion während der Kompilierung erstellt. Wenn setTimeout aufgerufen wird, erhält es die kompilierte Funktionsreferenz.
Beispiel 3:
Hier wird eine anonyme Funktion an setTimeout übergeben, die einen Abschluss für die Variable erstellt someFunction3. Wenn setTimeout ausgelöst wird, wurde someFunction3 ein Wert zugewiesen und die Funktion wird erfolgreich ausgeführt.
Beispiel 4:
Ähnlich wie Beispiel 2 wird die Funktion someFunction4 deklariert, wodurch seine Referenz ist für setTimeout verfügbar.
Zusätzliche Klarstellung:
Das obige ist der detaillierte Inhalt vonWarum schlägt dieser JavaScript-Code fehl, obwohl ähnliche Beispiele funktionieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!