Heim Web-Frontend js-Tutorial Verwenden der let-Anweisung zum Deklarieren des Bereichs in JavaScript (Bild- und Text-Tutorial)

Verwenden der let-Anweisung zum Deklarieren des Bereichs in JavaScript (Bild- und Text-Tutorial)

May 21, 2018 pm 01:40 PM
javascript js 作用域

Bitte beachten Sie zunächst, dass let etwas in ES6 ist, zumindest ist es mit IE-Browsern vor IE10 kompatibel, also seien Sie vorsichtig ... Schauen wir uns dann die Verwendung der let-Anweisung zum Deklarieren des Bereichs in JavaScript an

Syntax

let variable1 = value1
Nach dem Login kopieren

Parametervariable1
Der Name der zu deklarierenden Variablen.
Wert1
Der der Variablen zugewiesene Anfangswert.

BemerkungenVerwenden Sie die let-Anweisung, um eine Variable zu deklarieren, deren Gültigkeitsbereich auf den Block beschränkt ist, in dem sie deklariert ist. Sie können einer Variablen einen Wert zuweisen, wenn Sie sie deklarieren, oder Sie können der Variablen später im Skript einen Wert zuweisen.
Mit let deklarierte Variablen können nicht vor der Deklaration verwendet werden, da sonst ein Fehler auftritt.
Wenn Ihre Variable nicht in einer let-Anweisung initialisiert wird, wird ihr automatisch der JavaScript-Wert undefiniert zugewiesen.

Beispiel:

var l = 10;
{
  let l = 2;
  // At this point, l = 2.
}
// At this point, l = 10.

// Additional ways to declare a variable using let.
let index;
let name = "Thomas Jefferson";
let answer = 42, counter, numpages = 10;
let myarray = new Array();
Nach dem Login kopieren

Bereich auf Blockebene

for(var i = 0; i < 10; i++){}
console.log(i); //10

for(let j = 0; j < 10; j++){}
console.log(j); //"ReferenceError: j is not defined
Nach dem Login kopieren

Keine variable Förderung

console.log(a); // 输出undefined
console.log(b); // 报错ReferenceError
console.log(c); // 报错ReferenceError
var a = 2;
let b = 2;
Nach dem Login kopieren

Beachten Sie: Unterschied zwischen undefiniert und ReferenceError

Temporäre Totzone (TDZ)Solange Sie den aktuellen Bereich auf Blockebene betreten, sind die verwendeten Variablen bereits vorhanden, aber bevor sie deklariert werden, gehören sie dazu die tote Zone und kann nicht verwendet werden.
Hinweis: „typeof“ ist kein 100 % sicherer Vorgang mehr

typeof x; // ReferenceError
typeof y // undefined
let x;
Nach dem Login kopieren

Doppelte Deklarationen sind nicht zulässig

let x = 1;
let x; // "SyntaxError: Identifier &#39;x&#39; has already been declared

var y = 2;
var y = 3; // y = 3
Nach dem Login kopieren

Geltungsbereich auf Blockebene

// 匿名函数写法
(function () {
 var tmp = ...;
 ...
}());

// 块级作用域写法
{
 let tmp = ...;
 ...
}
Nach dem Login kopieren

Der strikte Modus von ES5 legt fest, dass Funktionen nur im Bereich der obersten Ebene deklariert werden können und innerhalb der Funktion in anderen Situationen (z. B. wenn Codeblöcke und Schleifencodeblöcke) einen Fehler melden.

// ES5
&#39;use strict&#39;;
if (true) {
 function f() {} // 报错
}
Nach dem Login kopieren

Aufgrund der Einführung des Bereichs auf Blockebene in ES6 kann diese Situation so verstanden werden, dass die Funktion im Bereich auf Blockebene deklariert wird, sodass kein Fehler gemeldet wird, sondern die geschweiften Klammern, die den Block bilden darf nicht fehlen

// 报错
&#39;use strict&#39;;
if (true)
 function f() {}
Nach dem Login kopieren

Die deklarierten globalen Variablen sind keine Attribute des Fensters mehr

"use strict";
var a = 1;
console.log(window.a) // 1

let b = 1;
console.log(window.b) // undefined
Nach dem Login kopieren

Das Obige habe ich für alle zusammengestellt. Ich hoffe, dass es in Zukunft für alle hilfreich sein wird.

Verwandte Artikel:

Detailliertes Verständnis und praktische Verwendung von Javascript Funktion (Code im Anhang)

JavaScript Grundlegende mentale Fähigkeiten (Bild- und Text-Tutorials, detaillierte Antworten für Sie)

Detaillierte Antworten zu JavaScript-Modulen

Das obige ist der detaillierte Inhalt vonVerwenden der let-Anweisung zum Deklarieren des Bereichs in JavaScript (Bild- und Text-Tutorial). 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ßer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
<🎜> obscur: Expedition 33 - So erhalten Sie perfekte Chroma -Katalysatoren
2 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)

Heiße Themen

Java-Tutorial
1677
14
PHP-Tutorial
1278
29
C#-Tutorial
1257
24
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.

C++ Smart Pointer: Von den Grundlagen bis zum Fortgeschrittenen C++ Smart Pointer: Von den Grundlagen bis zum Fortgeschrittenen May 09, 2024 pm 09:27 PM

Intelligente Zeiger sind C++-spezifische Zeiger, die Heap-Speicherobjekte automatisch freigeben und Speicherfehler vermeiden können. Zu den Typen gehören: unique_ptr: exklusiver Besitz, der auf ein einzelnes Objekt verweist. shared_ptr: Gemeinsamer Besitz, sodass mehrere Zeiger Objekte gleichzeitig verwalten können. schwacher_ptr: Schwache Referenz, erhöht nicht die Referenzanzahl und vermeidet Zirkelreferenzen. Verwendung: Verwenden Sie make_unique, make_shared und make_weak des std-Namespace, um intelligente Zeiger zu erstellen. Intelligente Zeiger geben automatisch Objektspeicher frei, wenn der Bereich endet. Erweiterte Verwendung: Sie können benutzerdefinierte Löschprogramme verwenden, um zu steuern, wie Objekte freigegeben werden. Intelligente Zeiger können dynamische Arrays effektiv verwalten und Speicherverluste verhindern.

See all articles