Inhaltsverzeichnis
In es5 werden in ES5 nur globaler Bereich und Funktionsbereich verwendet
Heim Web-Frontend Front-End-Fragen und Antworten Was ist der Unterschied zwischen ES5- und ES6-Bereichen?

Was ist der Unterschied zwischen ES5- und ES6-Bereichen?

Apr 11, 2022 pm 02:56 PM
es5 es6 作用域

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.

Was ist der Unterschied zwischen ES5- und ES6-Bereichen?

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

Beispiel

  var 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
Nach dem Login kopieren

    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()
Nach dem Login kopieren
. Ausführungsergebnisse. Die Variable i in der Funktion fun wird mit var deklariert. Das sogenannte Variablen-Hoisting bedeutet, dass Funktionsdeklarationen und Variablendeklarationen vom Interpreter immer stillschweigend an den Anfang des Methodenkörpers „gehievt“ werden. Das i hier ist also gleichbedeutend mit dem Erreichen der Spitze des Funktionsspaßes im Voraus, aber die Zuweisung wird immer noch ausgeführt, wenn i = 6 ausgeführt wird. Der obige Code entspricht tatsächlich:

var i = 5;
function fun(){
  var i;
  console.log(i);
  if(true){
    i = 6
    console.log(i)
  }
}
fun()
Nach dem Login kopieren
Wenn das erste i gedruckt wird, ist i gerade Deklariert, aber noch nicht zugewiesen (i wird in der if-Anweisung der Wert 6 zugewiesen), daher ist das erste gedruckte i undefiniert und das zweite gedruckte i ist 6
var i = 5;
function fun(){
  console.log(i);//5
  if(true){
    let i = 6
    console.log(i);//6
  }
}
fun()
Nach dem Login kopieren
Wenn Sie let verwenden, um die Variable i in der if-Anweisung zu deklarieren, Dann bilden die geschweiften Klammern {}, an denen sich die if-Anweisung befindet, einen Bereich auf Blockebene, und die in diesem Bereich deklarierten Variablen werden in diesem Bereich „gebunden“ und werden nicht mehr von äußeren Einflüssen beeinflusst (d. h. vorübergehende Totzone). ). Daher ist die erste i-Ausgabe beim Ausführen der Fun-Funktion var i=5 im globalen Bereich, und die i-Ausgabe in der if-Anweisung ist let i=6 im Blockebene-Bereich. Verhindern Sie dies von der Verwendung für die Schleifenzählung Die Variable wird als globale Variable durchgesickert

for(var i = 0; i < 3; i++){
  doSomething()
}
console.log(i)//3
Nach dem Login kopieren

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 kann

for(let i = 0; i < 3; i++){
  console.log(i)
}
console.log(i)//undefined
Nach dem Login kopieren
Wenn Sie let mit einem Bereich auf Blockebene verwenden, um i zu deklarieren, ist die hier deklarierte i-Variable nur innerhalb von for gültig Schleife in geschweiften Klammern {}. Der Zugriff auf Variablen im Bereich auf Blockebene im globalen Bereich führt zu undefinierten Merkmalen des Bereichs auf Blockebene. Mit let deklarierte Variablen sind nur im Bereich gültig ( derzeit innerhalb der geschweiften Klammern), ermöglicht also eine beliebige Verschachtelung, jede Ebene ist ein separater Bereich

2 Der innere Bereich kann denselben Namen wie die äußere Bereichsvariable haben (es werden keine Bereiche verwendet, ohne sich gegenseitig zu beeinträchtigen)
Was ist der Unterschied zwischen ES5- und ES6-Bereichen?3. let kann nur im aktuellen Bereich der obersten Ebene existieren

Hinweis: Wenn es in { } in if-Anweisungen und for-Anweisungen Variablen/Konstanten gibt, die durch let oder const deklariert wurden, gehört der Bereich von { } auch zum Blockbereich

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>
Nach dem Login kopieren

【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!

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

Video Face Swap

Video Face Swap

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

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)

Verwendung der Typedef-Struktur in der C-Sprache Verwendung der Typedef-Struktur in der C-Sprache May 09, 2024 am 10:15 AM

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.

So lösen Sie die in Java erwartete Variable So lösen Sie die in Java erwartete Variable May 07, 2024 am 02:48 AM

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

Vor- und Nachteile von Verschlüssen in js Vor- und Nachteile von Verschlüssen in js May 10, 2024 am 04:39 AM

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.

Was bedeutet include in c++? Was bedeutet include in c++? May 09, 2024 am 01:45 AM

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.

C++-Smartpointer: eine umfassende Analyse ihres Lebenszyklus C++-Smartpointer: eine umfassende Analyse ihres Lebenszyklus May 09, 2024 am 11:06 AM

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.

Können die Definition und der Aufruf von Funktionen in C++ verschachtelt werden? Können die Definition und der Aufruf von Funktionen in C++ verschachtelt werden? May 06, 2024 pm 06:36 PM

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.

Der Unterschied zwischen let und var in vue Der Unterschied zwischen let und var in vue May 08, 2024 pm 04:21 PM

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.

Es gibt mehrere Situationen, auf die dies in js hinweist Es gibt mehrere Situationen, auf die dies in js hinweist May 06, 2024 pm 02:03 PM

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.

See all articles