Lösung für das Problem von var in einer for-Schleife

Lösung für das Problem von var in einer for-Schleife

Vorwort

var ist eine Möglichkeit, Variablen in ES5 zu deklarieren. Ich habe immer gehört, dass beim Deklarieren von Variablen mit var das Problem auftritt, dass Schleifenvariablen zu globalen Variablen durchsickern, aber ich kann die Auswirkungen dieses „Globalen“ nicht immer herausfinden. Darüber hinaus ist nicht klar, wann das Ausgabeergebnis ein steigender/fallender Wert ist und wann die Ausgabe der gleiche Wert ist.

Reproduktion des Problems

für (var i = 1; i <= 5; i++) {
  setTimeout(Funktion Timer() {
    Konsole.log(i)
  }, ich * 1000)
}

Erwartetes Ergebnis: 12345

Druckergebnis: 66666

Lösung

Verschlüsse

für (var i = 1; i <= 5; i++) {
    (Funktion (j) {
        setTimeout(Funktion Timer() {
            konsole.log(j)
        }, j * 1000)
    })(ich)
}

setTimeout dritter Parameter

für (var i = 1; i <= 5; i++) {
   setzeTimeout(
       Funktion Timer(j) {
           konsole.log(j)
       },
       ich * 1000,
       ich
   )
}

Verwenden Sie let, um i zu definieren

für (lass i = 1; i <= 5; i++) {
    setTimeout(Funktion Timer() {
        Konsole.log(i)
    }, ich * 1000)
}

lassen

Bezüglich let gilt: Das aktuelle i ist nur in dieser Schleife gültig, und i ist in jeder Schleife tatsächlich eine neue Variable.

Die JavaScript-Engine merkt sich intern den Wert der vorherigen Schleife und führt beim Initialisieren der Variable i dieser Schleife Berechnungen basierend auf der vorherigen Schleife durch.

Darüber hinaus verfügt die For-Schleife über eine weitere Besonderheit: Der Teil, der die Schleifenvariable festlegt, ist ein übergeordneter Bereich, und der Schleifenkörper ist ein separater untergeordneter Bereich.

für (sei i = 0; i < 3; i++) {
sei i = 'abc';
konsole.log(i);
}
//ABC
//ABC
//ABC

Zusammenfassen

Dies ist das Ende dieses Artikels zur Lösung der Probleme, die bei der Verwendung von var for-Schleifen auftreten. Weitere Informationen zu Problemen mit var for-Schleifen finden Sie in früheren Artikeln auf 123WORDPRESS.COM oder in den folgenden verwandten Artikeln. Ich hoffe, Sie werden 123WORDPRESS.COM auch in Zukunft unterstützen!

Das könnte Sie auch interessieren:
  • js for-Schleife, warum müssen wir var hinzufügen, um die Variable i zu definieren
  • Der Unterschied zwischen var und let in der jQuery-For-Schleife
  • Detaillierte Erklärung des Unterschieds zwischen let und var in der es6-for-Schleife

<<:  Entdecken Sie die Wahrheit hinter dem Neuladevorgang in Nginx

>>:  Detaillierte Erklärung des Codes zum Abfragen von Daten eines bestimmten Tages, Monats oder Jahres in MySQL

Artikel empfehlen

Vue verwendet Echarts, um ein dreidimensionales Balkendiagramm zu implementieren

In diesem Artikel wird der spezifische Code von V...

Detaillierte Erklärung zum effizienten MySQL-Paging

Vorwort Normalerweise wird für MySQL-Abfragen mit...

So entwerfen und optimieren Sie MySQL-Indizes

Inhaltsverzeichnis Was ist ein Index? Prinzip der...

Implementierung von TypeScript im React-Projekt

Inhaltsverzeichnis 1. Einleitung 2. Nutzung Zusta...

So verwenden Sie CSS, um mehrere Bilder horizontal in der Mitte anzuzeigen

Lassen Sie mich zunächst über die Implementierung...

So löschen Sie zusätzliche Kernel in Ubuntu

Schritt 1: Den aktuellen Kernel anzeigen rew $ un...

MySQL 5.7.18 Green Edition Download- und Installations-Tutorial

Dieser Artikel beschreibt den detaillierten Vorga...

Verbesserungen am Webserver zur Verbesserung der Website-Leistung

<br />Im ersten Abschnitt dieser Reihe haben...

Detaillierte Erklärung des Integer-Datentyps tinyint in MySQL

Inhaltsverzeichnis 1.1Tinyint-Typbeschreibung 1.2...

Ausführliches Tutorial zur Installation von MySQL 8.0.19 (Windows 64 Bit)

Inhaltsverzeichnis MySQL initialisieren MySQL-Die...

Detaillierte Erklärung der neuen Array-Methoden in JavaScript es6

Inhaltsverzeichnis 1. fürJedes() 2. arr.filter() ...