


Was ist der Unterschied zwischen ES5- und ES6-Bereichen?
Unterschied: In es5 gibt es nur zwei Arten von Bereichen: globalen Bereich und Funktionsbereich, während es in es6 drei Arten von Bereichen gibt: globalen Bereich, Funktionsbereich und Bereich auf Blockebene. Ein neuer Bereich auf Blockebene wird hinzugefügt. . Die Rolle des Bereichs auf Blockebene: Er kann das Problem des Überschreibens äußerer Variablen aufgrund der Heraufstufung innerer Bereichsvariablen lösen und verhindern, dass Variablen, die für die Schleifenzählung verwendet werden, in globale Variablen gelangen.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, ECMAScript Version 6, Dell G3-Computer
Der Unterschied zwischen es5 und es6 in Bezug auf den Umfang:
Es gibt nur zwei Arten von Bereichen in es5: globaler Bereich Domäne und Funktionsumfang
In es6 gibt es drei Arten von Bereichen: globaler Bereich, Funktionsbereich und Bereich auf Blockebene
In es5 werden in ES5 nur globaler Bereich und Funktionsbereich verwendet
Variablen werden mit var deklariert. Variablen, die mit var deklariert werden, können im globalen Bereich oder im lokalen Bereich vorhanden sein. Die spezifischen Situationen sind wie folgt:
Drei Situationen mit einem globalen Bereich
a. Variablen, die außerhalb der Funktion deklariert wurden, haben einen globalen Gültigkeitsbereich.b. Variablen, die nicht für die direkte Zuweisung definiert sind, werden automatisch als globale Variablen deklariert Umfang ( Funktionsumfang)
Der Umfang der Variablen im Funktionskörper
Auf innerhalb der Funktion definierte Variablen kann nur innerhalb der Funktion zugegriffen werden
Beispielvar a = 1; console.log(a);// 1 此处a为全局变量,在全局作用域下都可访问得到 b = 2 console.log(b); // 2 此处b未被var定义,而是被直接赋值,自动声明为全局变量 function fun() { var c = 3; console.log(c);//3 此处c存在在函数作用域中,仅在函数fun中可访问 } fun() console.log(c);// undefined 全局作用域下访问函数作用域中的变量c,得到undefined
- Neuer Bereich auf Blockebene in Es6
-
Der Bereich auf Blockebene kann einfach verstanden werden als: der in geschweifte Klammern {} eingeschlossene Inhalt, der einen eigenen Bereich bilden kann. Variablen im Bereich auf Blockebene werden durch let und const deklariert
Warum brauchen wir den Bereich auf Blockebene?
1. Lösen Sie das Problem der Variablenheraufstufung im inneren Bereich, die dazu führt, dass äußere Variablen überschrieben werden.
var i = 5; function fun(){ console.log(i);//undefined if(true){ var i = 6 console.log(i);//6 } } fun()
var i = 5; function fun(){ var i; console.log(i); if(true){ i = 6 console.log(i) } } fun()
var i = 5; function fun(){ console.log(i);//5 if(true){ let i = 6 console.log(i);//6 } } fun()
for(var i = 0; i < 3; i++){ doSomething() } console.log(i)//3
Der obige Code verwendet var, um die i-Variable für die Schleife zu deklarieren. Idealerweise sollte i nur innerhalb des Schleifenkörpers gültig sein, aber hier ist i verfügbar und befindet sich im globalen Bereich, sodass nach dem Ende der Schleife immer noch global auf den Wert von i zugegriffen werden kannfor(let i = 0; i < 3; i++){
console.log(i)
}
console.log(i)//undefined
2 Der innere Bereich kann denselben Namen wie die äußere Bereichsvariable haben (es werden keine Bereiche verwendet, ohne sich gegenseitig zu beeinträchtigen)3. let kann nur im aktuellen Bereich der obersten Ebene existieren
Beispiele zum Umfang
<script type="text/javascript"> { var a = 1; console.log(a); // 1 } console.log(a); // 1 // 可见,通过var定义的变量可以跨块作用域访问到。 (function A() { var b = 2; console.log(b); // 2 })(); // console.log(b); // 报错, // 可见,通过var定义的变量不能跨函数作用域访问到 if(true) { var c = 3; } console.log(c); // 3 for(var i = 0; i < 4; i++) { var d = 5; }; console.log(i); // 4 (循环结束i已经是4,所以此处i为4) console.log(d); // 5 // if语句和for语句中用var定义的变量可以在外面访问到, // 可见,if语句和for语句属于块作用域,不属于函数作用域。 { var a = 1; let b = 2; const c = 3; { console.log(a); // 1 子作用域可以访问到父作用域的变量 console.log(b); // 2 子作用域可以访问到父作用域的变量 console.log(c); // 3 子作用域可以访问到父作用域的变量 var aa = 11; let bb = 22; const cc = 33; } console.log(aa); // 11 // 可以跨块访问到子 块作用域 的变量 // console.log(bb); // 报错 bb is not defined // console.log(cc); // 报错 cc is not defined } </script>
【Verwandte Empfehlungen: Javascript-Video-Tutorial,
Web-Frontend】
Das obige ist der detaillierte Inhalt vonWas ist der Unterschied zwischen ES5- und ES6-Bereichen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

typedef struct wird in der C-Sprache zum Erstellen von Strukturtypaliasen verwendet, um die Verwendung von Strukturen zu vereinfachen. Es weist einem neuen Datentyp ein Alias auf eine vorhandene Struktur zu, indem es den Strukturalias angibt. Zu den Vorteilen gehören verbesserte Lesbarkeit, Wiederverwendung von Code und Typprüfung. Hinweis: Die Struktur muss vor der Verwendung eines Alias definiert werden. Der Alias muss im Programm eindeutig sein und nur innerhalb des Bereichs gültig sein, in dem er deklariert ist.

Variablenerwartungsausnahmen in Java können gelöst werden durch: Initialisierung von Variablen; Verwendung von Nullwerten; Verwendung von Überprüfungen und Zuweisungen;

Zu den Vorteilen von JavaScript-Abschlüssen gehören die Aufrechterhaltung des variablen Bereichs, die Aktivierung von modularem Code, die verzögerte Ausführung und die Ereignisbehandlung. Zu den Nachteilen zählen Speicherverluste, erhöhte Komplexität, Leistungsaufwand und Auswirkungen der Bereichskette.

Die Präprozessoranweisung #include in C++ fügt den Inhalt einer externen Quelldatei in die aktuelle Quelldatei ein und kopiert ihren Inhalt an die entsprechende Stelle in der aktuellen Quelldatei. Wird hauptsächlich zum Einschließen von Header-Dateien verwendet, die im Code benötigte Deklarationen enthalten, z. B. #include <iostream>, um Standard-Eingabe-/Ausgabefunktionen einzubinden.

Lebenszyklus von C++-Smartpointern: Erstellung: Smartpointer werden erstellt, wenn Speicher zugewiesen wird. Eigentumsübertragung: Übertragen Sie das Eigentum durch einen Umzugsvorgang. Freigabe: Speicher wird freigegeben, wenn ein Smart Pointer den Gültigkeitsbereich verlässt oder explizit freigegeben wird. Objektzerstörung: Wenn das Objekt, auf das gezeigt wird, zerstört wird, wird der intelligente Zeiger zu einem ungültigen Zeiger.

Dürfen. C++ erlaubt verschachtelte Funktionsdefinitionen und Aufrufe. Externe Funktionen können integrierte Funktionen definieren und interne Funktionen können direkt innerhalb des Bereichs aufgerufen werden. Verschachtelte Funktionen verbessern die Kapselung, Wiederverwendbarkeit und Bereichskontrolle. Interne Funktionen können jedoch nicht direkt auf lokale Variablen externer Funktionen zugreifen, und der Rückgabewerttyp muss mit der Deklaration der externen Funktion übereinstimmen. Interne Funktionen können nicht selbstrekursiv sein.

In Vue gibt es beim Deklarieren von Variablen zwischen let und var einen Unterschied im Gültigkeitsbereich: Gültigkeitsbereich: var hat einen globalen Gültigkeitsbereich und let hat einen Gültigkeitsbereich auf Blockebene. Bereich auf Blockebene: var erstellt keinen Bereich auf Blockebene, let erstellt einen Bereich auf Blockebene. Neudeklaration: var ermöglicht die Neudeklaration von Variablen im gleichen Bereich, let jedoch nicht.

Zu den Zeigertypen gehören in JavaScript: 1. Globales Objekt; 3. Konstruktoraufruf; 5. Pfeilfunktion (erbt dies); Darüber hinaus können Sie mit den Methoden bind(), call() und apply() explizit festlegen, worauf dies hinweist.
