Temporäre Totzone
Solange der Befehl let
im Bereich auf Blockebene existiert, sind die von ihm deklarierten Variablen für diesen Bereich „bindend“ und nicht länger gültig durch äußere Einflüsse beeinflusst werden.
var tmp = 123; if (true) { tmp = 'abc'; // ReferenceError let tmp; }
Im obigen Code gibt es eine globale Variable tmp
, aber let
deklariert eine lokale Variable tmp
im Bereich auf Blockebene, wodurch letztere diesen Bereich auf Blockebene bindet. also in let
Bevor Sie eine Variable deklarieren, führt die Zuweisung eines Werts zu tmp
zu einem Fehler.
ES6 legt klar fest, dass, wenn in einem Block die Befehle let
und const
vorhanden sind, die von diesen Befehlen in diesem Block deklarierten Variablen von Anfang an einen geschlossenen Bereich bilden. Jede Verwendung dieser Variablen vor der Deklaration führt zu einem Fehler.
Kurz gesagt, innerhalb des Codeblocks ist die Variable erst verfügbar, wenn sie mit dem Befehl let
deklariert wird. Syntaktisch wird dies als „temporäre Totzone“ (TDZ) bezeichnet.
if (true) { // TDZ开始 tmp = 'abc'; // ReferenceError console.log(tmp); // ReferenceError let tmp; // TDZ结束 console.log(tmp); // undefined tmp = 123; console.log(tmp); // 123 }
Bevor der Befehl let
im obigen Code die Variable tmp
deklariert, gehört sie zur „toten Zone“ der Variablen tmp
.
„Vorübergehende Totzone“ bedeutet auch, dass typeof
kein 100 % sicherer Betrieb mehr möglich ist.
typeof x; // ReferenceError let x;
Im obigen Code wird die Variable x
mit dem Befehl let
deklariert, sodass sie vor der Deklaration zur „toten Zone“ von x
gehört, solange die Variable verwendet wird, wird ein Fehler gemeldet. Daher wird ein typeof
ausgelöst, wenn ReferenceError
ausgeführt wird.
Zum Vergleich: Wenn eine Variable überhaupt nicht deklariert ist, wird bei Verwendung von typeof
kein Fehler gemeldet.
typeof undeclared_variable // "undefined"
Im obigen Code ist undeclared_variable
ein Variablenname, der nicht existiert, und das Ergebnis ist „undefiniert“. Daher war der let
-Operator, bevor es kein typeof
gab, zu 100 % sicher und würde niemals einen Fehler melden. Das stimmt nicht mehr. Dieses Design soll jedem helfen, gute Programmiergewohnheiten zu entwickeln. Variablen müssen nach ihrer Deklaration verwendet werden, andernfalls wird ein Fehler gemeldet.
Einige „tote Zonen“ sind versteckt und schwer zu finden.
function bar(x = y, y = 2) { return [x, y]; } bar(); // 报错
Im obigen Code liegt der Grund, warum der Aufruf der Funktion bar
einen Fehler meldet (einige Implementierungen melden möglicherweise keinen Fehler), darin, dass der Standardwert des Parameters x
einem anderen Parameter , und zu diesem Zeitpunkt y
Es wurde noch nicht deklariert, es handelt sich also um eine „tote Zone“. Wenn der Standardwert von y
y
ist, wird kein Fehler gemeldet, da x
zu diesem Zeitpunkt deklariert wurde. x
function bar(x = 2, y = x) { return [x, y]; } bar(); // [2, 2]Darüber hinaus meldet der folgende Code auch einen Fehler, der sich vom Verhalten von
unterscheidet. var
// 不报错 var x = x; // 报错 let x = x; // ReferenceError: x is not definedDer vom obigen Code gemeldete Fehler ist auch auf die vorübergehende tote Zone zurückzuführen. Wenn Sie
zum Deklarieren einer Variablen verwenden, wird ein Fehler gemeldet, solange die Variable verwendet wird, bevor die Deklaration abgeschlossen ist. Die obige Zeile gehört zu dieser Situation. Bevor die Deklarationsanweisung der Variablen let
ausgeführt wird, wird der Wert von x
übernommen, was zu einem Fehler „x ist nicht definiert“ führt. x
, let
-Anweisungen erfolgt. Dies dient hauptsächlich dazu, Laufzeitfehler zu reduzieren und zu verhindern, dass die Variable verwendet wird, bevor sie deklariert wird, was zu unerwarteten Folgen führt Verhalten. Fehler wie dieser kommen in ES5 sehr häufig vor, und da diese Bestimmung nun vorhanden ist, können sie leicht vermieden werden. const
Was ist der Unterschied zwischen der Verwendung von js string indexof und der Suche
Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in das Konzept der „temporären Totzone' in JS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

JavaScript -Kerndatentypen sind in Browsern und Knoten.js konsistent, werden jedoch unterschiedlich als die zusätzlichen Typen behandelt. 1) Das globale Objekt ist ein Fenster im Browser und global in node.js. 2) Node.js 'eindeutiges Pufferobjekt, das zur Verarbeitung von Binärdaten verwendet wird. 3) Es gibt auch Unterschiede in der Leistung und Zeitverarbeitung, und der Code muss entsprechend der Umgebung angepasst werden.

JavaScriptUSESTWOTYPESOFCOMMENMENTEN: Einzelzeilen (//) und Multi-Linie (//). 1) Verwendung // Forquicknotesorsingle-Linexplanationen.2 Verwendung // ForlongerExPlanationsCompomentingingoutblocks-

Der Hauptunterschied zwischen Python und JavaScript sind die Typ -System- und Anwendungsszenarien. 1. Python verwendet dynamische Typen, die für wissenschaftliche Computer- und Datenanalysen geeignet sind. 2. JavaScript nimmt schwache Typen an und wird in Front-End- und Full-Stack-Entwicklung weit verbreitet. Die beiden haben ihre eigenen Vorteile bei der asynchronen Programmierung und Leistungsoptimierung und sollten bei der Auswahl gemäß den Projektanforderungen entschieden werden.

Ob die Auswahl von Python oder JavaScript vom Projekttyp abhängt: 1) Wählen Sie Python für Datenwissenschafts- und Automatisierungsaufgaben aus; 2) Wählen Sie JavaScript für die Entwicklung von Front-End- und Full-Stack-Entwicklung. Python ist für seine leistungsstarke Bibliothek in der Datenverarbeitung und -automatisierung bevorzugt, während JavaScript für seine Vorteile in Bezug auf Webinteraktion und Full-Stack-Entwicklung unverzichtbar ist.

Python und JavaScript haben jeweils ihre eigenen Vorteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1. Python ist leicht zu erlernen, mit prägnanter Syntax, die für Datenwissenschaft und Back-End-Entwicklung geeignet ist, aber eine langsame Ausführungsgeschwindigkeit hat. 2. JavaScript ist überall in der Front-End-Entwicklung und verfügt über starke asynchrone Programmierfunktionen. Node.js macht es für die Entwicklung der Vollstapel geeignet, die Syntax kann jedoch komplex und fehleranfällig sein.

JavaScriptisnotbuiltoncorc; Es ist angehört, dass sich JavaScriptWasdedeSthatrunsonGineoFtencninc.

JavaScript kann für die Entwicklung von Front-End- und Back-End-Entwicklung verwendet werden. Das Front-End verbessert die Benutzererfahrung durch DOM-Operationen, und die Back-End-Serveraufgaben über node.js. 1. Beispiel für Front-End: Ändern Sie den Inhalt des Webseitentextes. 2. Backend Beispiel: Erstellen Sie einen Node.js -Server.

Die Auswahl von Python oder JavaScript sollte auf Karriereentwicklung, Lernkurve und Ökosystem beruhen: 1) Karriereentwicklung: Python ist für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet, während JavaScript für die Entwicklung von Front-End- und Full-Stack-Entwicklung geeignet ist. 2) Lernkurve: Die Python -Syntax ist prägnant und für Anfänger geeignet; Die JavaScript -Syntax ist flexibel. 3) Ökosystem: Python hat reichhaltige wissenschaftliche Computerbibliotheken und JavaScript hat ein leistungsstarkes Front-End-Framework.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

Dreamweaver CS6
Visuelle Webentwicklungstools
