Heim Web-Frontend js-Tutorial Ausführliche Erklärung des Hebens in JavaScript

Ausführliche Erklärung des Hebens in JavaScript

Aug 20, 2017 am 10:10 AM
javascript js

Funktionsdeklarationen und Variablendeklarationen werden vom JavaScript-Interpreter immer implizit an den Anfang des Bereichs gehoben, der sie enthält. Der folgende Artikel führt Sie hauptsächlich in die relevanten Informationen zum Heben von Variablen (Variablenheben und Heben von Funktionsdeklarationen) in JavaScript ein. Lassen Sie uns gemeinsam einen Blick darauf werfen.

Dieser Artikel stellt Ihnen hauptsächlich den relevanten Inhalt zum Heben von Variablen (Heben von Variablen und Funktionsdeklarationen) in JavaScript vor. Ich werde im Folgenden nicht viel sagen die ausführliche Einleitung.

So „verschieben“ Sie Funktionsdeklarationen/Variablen an den oberen Rand des Bereichs.

Der Begriff Hoisting wird in vielen JavaScript-Blogbeiträgen verwendet, um das Parsen von Identifikatoren zu erklären. Tatsächlich wird das Wort „Hoisting“ verwendet, um zu erklären, wie Variablen- und Funktionsdeklarationen an die Spitze der Funktion oder des globalen Gültigkeitsbereichs gehoben werden. Sie werden diesen Begriff in keiner JavaScript-Dokumentation finden, und was wir „Hoisting“ nennen, verwendet seine wörtliche Bedeutung lediglich als Metapher.

Wenn Sie bereits über ein grundlegendes Verständnis der Funktionsweise von JavaScript-Scoping verfügen, kann Ihnen ein tieferes Verständnis von Hoisting dabei helfen, eine stärkere Grundlage zu schaffen. (Anmerkung von Fool's Wharf: Als allgemeines Konzept in JavaScript werden das Heben von Variablen und das Heben von Funktionsdeklarationen häufig in Front-End-Entwicklungsinterviews gefragt oder erscheinen in schriftlichen Testfragen für die Front-End-Entwicklung. Dies zeigt, wie wichtig es ist, Heben (Heben) zu verstehen. .)

Um die Grundlagen besser zu verstehen, schauen wir uns noch einmal an, was „Heben“ eigentlich bedeutet. Zur Erinnerung: JavaScript ist eine interpretierte Sprache, die sich von kompilierten Sprachen unterscheidet, was bedeutet, dass JS-Code Zeile für Zeile ausgeführt wird.

Betrachten Sie das folgende Beispiel:


console.log(notyetdeclared);
// 打印 'undefined'
 
var notyetdeclared = 'now it is declared';
 
hoisting();
 
function hoisting(){
 console.log(notyetdeclared);
 // 打印 'undefined'
 
 var notyetdeclared = 'declared differently';
 
 console.log(notyetdeclared);
 // 打印 'declared differently'
}
Nach dem Login kopieren

Stellen Sie nach der Analyse des obigen Beispielcodes einige Fragen:

  • Zeile 6, warum kann auf diese Funktion zugegriffen werden, bevor sie deklariert wird?

  • Zeile 1, es wird kein Fehler ausgegeben. Liegt es daran, dass die Variable notyetdeclared zu diesem Zeitpunkt nicht existiert?

  • In Zeile 4 wurde notyetdeclared im globalen Bereich deklariert. Warum ist es immer noch undefiniert, wenn es in Zeile 9 gedruckt wird?

JavaScript ist sehr logisch und für all diese seltsamen Probleme gibt es eine klare Erklärung.

Beginnen wir ganz oben und erklären, dass bei der Ausführung von Code in JavaScript ein Ausführungskontext eingerichtet wird. Es gibt zwei Haupttypen von Ausführungskontexten in JavaScript: den globalen Ausführungskontext und den Funktionsausführungskontext (Fool's Pier Hinweis: Achten Sie besonders darauf, dass sich der Ausführungskontext von dem Kontext unterscheidet, über den wir normalerweise sprechen. Der Ausführungskontext bezieht sich auf den Bereich und den Der übliche Kontext ist der Wert, auf den hiermit verwiesen wird). Da JavaScript auf einem Single-Threaded-Ausführungsmodell basiert, kann jeweils nur ein Codeteil ausgeführt werden.

Für unseren obigen Code ist der Prozess wie in der Abbildung dargestellt:

Der Aufrufstapel von oben Beispielcode:

  • Das Programm startet die Ausführung aus dem globalen Ausführungskontext auf dem Stapel.

  • Wenn die Funktion hoisting() aufgerufen wird, wird ein neuer Funktionsausführungskontext auf den Stapel verschoben und der globale Ausführungskontext angehalten.

  • Nachdem die Ausführung von hoisting() abgeschlossen ist, wird der Ausführungskontext von hoisting() vom Stapel entfernt und der globale Ausführungskontext wiederhergestellt.

Dieser Vorgang ist selbsterklärend, erklärt jedoch nicht wirklich die Ausnahme, die wir beim Ausführen des Beispielcodes gesehen haben. Während der Ausführungskontext die Ausführung von Code verfolgt, verfolgt die lexikalische Umgebung die Zuordnung von Bezeichnern zu bestimmten Variablen. Die lexikalische Umgebung ist im Grunde die interne Implementierung des Scoping-Mechanismus von JavaScript. Typischerweise ist eine lexikalische Umgebung mit einer bestimmten Struktur von JavaScript-Code verknüpft, beispielsweise einer Funktion oder einem For-Schleifen-Codeblock. Immer wenn eine Funktion erstellt wird, wird ein Verweis auf die lexikalische Umgebung, in der sie erstellt wurde, in einer internen Eigenschaft namens [[Environment]] übergeben.

Alle diese Begriffe decken ein einfaches und sehr logisches Konzept ab. Lassen Sie zu, dass es abgebaut wird. Lexikalische Umgebung ist ein interessanter Name, der verwendet wird, um Variablen und Funktionen innerhalb eines Codeblocks zu verfolgen. Neben der Verfolgung lokaler Variablen, Funktionsdeklarationen und Parameter verfolgt jede lexikalische Umgebung auch die übergeordnete lexikalische Umgebung. Daher wird der obige Beispielcode in der JavaScript-Engine auf diese Weise analysiert. Die lexikalische Umgebung des obigen Codes ist wie in der Abbildung dargestellt:

Hinweis:

Wenn Sie Verständnisschwierigkeiten haben, schauen Sie sich bitte die folgenden drei Artikel an:

  • Detailliertes Verständnis von Umfang und Kontext in JavaScript

  • Umfang und Abschluss des JavaScript-Kernkonzepts

  • Beispielanalyse des JavaScript-Umfangs

Um einen Bezeichner in einer lexikalischen Umgebung aufzulösen, sucht die JavaScript-Engine nach Verweisen auf die aktuelle Umgebung. Wenn kein Verweis gefunden wird, wechseln Sie mit [[environment]] zur externen Umgebung. Dies wird so lange fortgesetzt, bis der Bezeichner gefunden wird oder ein „nicht definierter“ Fehler ausgegeben wird.

Grundsätzlich ist die Ausführung von JavaScript-Code in zwei Phasen unterteilt. In der ersten Phase werden alle Variablen- und Funktionsdeklarationen in der aktuellen lexikalischen Umgebung registriert. Nach Abschluss beginnt die zweite Phase der JavaScript-Ausführung!

Um Phase eins näher zu erläutern: Sie funktioniert in zwei Schritten.

  • Scannen Sie den Code in der aktuellen Funktionsdeklaration. Funktionsausdrücke und Pfeilfunktionen werden übersprungen. Für jede erkannte Funktion wird eine neue Funktion erstellt und unter Verwendung des Funktionsnamens an die Umgebung gebunden. Wenn der Name des Bezeichners bereits existiert, wird sein Wert überschrieben.

  • Scannen Sie dann die Variablen der aktuellen Umgebung. Suchen Sie nach Variablen, die mit var definiert sind, und nach Variablen, die außerhalb anderer Funktionen platziert sind, und registrieren Sie einen Bezeichner, dessen Wert auf undefiniert initialisiert wird. Wenn der Bezeichner vorhanden ist, bleibt der Wert unverändert.

Hinweis: Mit let und const definierte Blockvariablen unterscheiden sich geringfügig von var. Mehr dazu erfahren Sie in einem anderen Artikel.

Da Sie nun über ein gewisses Verständnis des Grundkonzepts der lexikalischen Umgebung verfügen sollten, kehren wir zum Beispielcode zurück und erläutern diese Probleme.

Beim Festlegen des globalen Kontexts wird die Umgebung gescannt und die Funktion hoisting() an den Bezeichner angehängt. Anschließend wird im nächsten Schritt die Variable notyetdeclared registriert und ihr Wert auf undefiniert initialisiert. Befolgen Sie diesen Schritt, um den Code besser zu verstehen.

Erläutern wir nun die drei im Beispielcode aufgeworfenen Fragen:

Zeile 6, warum kann die Funktion vor dem Zugriff deklariert werden? ?

In Phase 1 wurde die Funktion hoisting() im Bezeichner registriert. Wenn die Ausführung des JS-Codes im globalen Ausführungskontext von Phase 2 beginnt, sucht er nach der lexikalischen Umgebung von hoisting und Die Funktion wird vor ihrer Definition gefunden.

Zeile 1, es wird kein Fehler ausgegeben. Liegt es daran, dass die Variable notyetdeclared zu diesem Zeitpunkt nicht existiert?

In ähnlicher Weise wird notyetdeclared für den Bezeichner registriert und in Phase 1 auf „undefiniert“ initialisiert, sodass kein Fehler ausgegeben wird.

Abschließend

In Zeile 4 wurde notyetdeclared im globalen Bereich deklariert. Warum ist es immer noch undefiniert, wenn es in Zeile 9 gedruckt wird?

Jetzt betreten wir die Funktionshebeumgebung. In Phase 1 wird notyetdeclared registriert und auf undefiniert initialisiert, da die Variablen von notyetdeclared in dieser lexikalischen Umgebung noch nicht registriert wurden. Anders wäre die Situation, wenn Zeile 12 nicht das Schlüsselwort var enthalten würde.

Hoffentlich ist jetzt klar, dass Hoisting in JavaScript nur eine Perspektive ist, die wir verwenden, um die Prinzipien dahinter zu erklären. Technisch gesehen verschieben sich Funktionen und Variablen nirgendwo.

Zusammenfassung

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung des Hebens in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript Dec 17, 2023 pm 02:54 PM

So implementieren Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem. Einführung: Mit der kontinuierlichen Weiterentwicklung der Technologie ist die Spracherkennungstechnologie zu einem wichtigen Bestandteil des Bereichs der künstlichen Intelligenz geworden. Das auf WebSocket und JavaScript basierende Online-Spracherkennungssystem zeichnet sich durch geringe Latenz, Echtzeit und plattformübergreifende Eigenschaften aus und hat sich zu einer weit verbreiteten Lösung entwickelt. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem implementieren.

Wesentliche Tools für die Aktienanalyse: Lernen Sie die Schritte zum Zeichnen von Kerzendiagrammen mit PHP und JS Wesentliche Tools für die Aktienanalyse: Lernen Sie die Schritte zum Zeichnen von Kerzendiagrammen mit PHP und JS Dec 17, 2023 pm 06:55 PM

Wesentliche Tools für die Aktienanalyse: Lernen Sie die Schritte zum Zeichnen von Kerzendiagrammen in PHP und JS. Mit der rasanten Entwicklung des Internets und der Technologie ist der Aktienhandel für viele Anleger zu einer wichtigen Möglichkeit geworden. Die Aktienanalyse ist ein wichtiger Teil der Anlegerentscheidung, und Kerzendiagramme werden häufig in der technischen Analyse verwendet. Wenn Sie lernen, wie man Kerzendiagramme mit PHP und JS zeichnet, erhalten Anleger intuitivere Informationen, die ihnen helfen, bessere Entscheidungen zu treffen. Ein Candlestick-Chart ist ein technischer Chart, der Aktienkurse in Form von Candlesticks anzeigt. Es zeigt den Aktienkurs

Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Apr 03, 2024 am 11:55 AM

Die Technologie zur Gesichtserkennung und -erkennung ist bereits eine relativ ausgereifte und weit verbreitete Technologie. Derzeit ist JS die am weitesten verbreitete Internetanwendungssprache. Die Implementierung der Gesichtserkennung und -erkennung im Web-Frontend hat im Vergleich zur Back-End-Gesichtserkennung Vor- und Nachteile. Zu den Vorteilen gehören die Reduzierung der Netzwerkinteraktion und die Echtzeiterkennung, was die Wartezeit des Benutzers erheblich verkürzt und das Benutzererlebnis verbessert. Die Nachteile sind: Es ist durch die Größe des Modells begrenzt und auch die Genauigkeit ist begrenzt. Wie implementiert man mit js die Gesichtserkennung im Web? Um die Gesichtserkennung im Web zu implementieren, müssen Sie mit verwandten Programmiersprachen und -technologien wie JavaScript, HTML, CSS, WebRTC usw. vertraut sein. Gleichzeitig müssen Sie auch relevante Technologien für Computer Vision und künstliche Intelligenz beherrschen. Dies ist aufgrund des Designs der Webseite erwähnenswert

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen Dec 17, 2023 pm 05:30 PM

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript Dec 17, 2023 am 09:39 AM

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript. Im heutigen digitalen Zeitalter müssen immer mehr Unternehmen und Dienste Online-Reservierungsfunktionen bereitstellen. Es ist von entscheidender Bedeutung, ein effizientes Online-Reservierungssystem in Echtzeit zu implementieren. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Reservierungssystem implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist WebSocket? WebSocket ist eine Vollduplex-Methode für eine einzelne TCP-Verbindung.

Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Dec 17, 2023 pm 12:09 PM

Einführung in die Verwendung von JavaScript und WebSocket zur Implementierung eines Online-Bestellsystems in Echtzeit: Mit der Popularität des Internets und dem Fortschritt der Technologie haben immer mehr Restaurants damit begonnen, Online-Bestelldienste anzubieten. Um ein Echtzeit-Online-Bestellsystem zu implementieren, können wir JavaScript und WebSocket-Technologie verwenden. WebSocket ist ein Vollduplex-Kommunikationsprotokoll, das auf dem TCP-Protokoll basiert und eine bidirektionale Kommunikation zwischen Client und Server in Echtzeit realisieren kann. Im Echtzeit-Online-Bestellsystem, wenn der Benutzer Gerichte auswählt und eine Bestellung aufgibt

PHP- und JS-Entwicklungstipps: Beherrschen Sie die Methode zum Zeichnen von Aktienkerzendiagrammen PHP- und JS-Entwicklungstipps: Beherrschen Sie die Methode zum Zeichnen von Aktienkerzendiagrammen Dec 18, 2023 pm 03:39 PM

Mit der rasanten Entwicklung der Internetfinanzierung sind Aktieninvestitionen für immer mehr Menschen zur Wahl geworden. Im Aktienhandel sind Kerzendiagramme eine häufig verwendete Methode der technischen Analyse. Sie können den sich ändernden Trend der Aktienkurse anzeigen und Anlegern helfen, genauere Entscheidungen zu treffen. In diesem Artikel werden die Entwicklungskompetenzen von PHP und JS vorgestellt, der Leser wird zum Verständnis des Zeichnens von Aktienkerzendiagrammen geführt und es werden spezifische Codebeispiele bereitgestellt. 1. Aktien-Kerzendiagramme verstehen Bevor wir uns mit dem Zeichnen von Aktien-Kerzendiagrammen befassen, müssen wir zunächst verstehen, was ein Kerzendiagramm ist. Candlestick-Charts wurden von den Japanern entwickelt

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Dec 17, 2023 pm 05:13 PM

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

See all articles