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

Mysql teilt Zeichenfolge durch gespeicherte Prozedur in Array auf

Um einen String in ein Array aufzuteilen, müssen ...

Vorteile und Nachteile des MySQL Advanced Learning Index sowie Nutzungsregeln

1. Vor- und Nachteile von Indizes Vorteile: schne...

Einfache Schritte zum Konfigurieren des Nginx-Reverse-Proxys mit SSL

Vorwort Ein Reverse-Proxy ist ein Server, der übe...

Implementierung der privaten Docker-Bibliothek

Die Installation und Bereitstellung eines private...

Detaillierte Erklärung zum Anzeigen der Anzahl der MySQL-Server-Threads

In diesem Artikel wird anhand eines Beispiels bes...

Über Zabbix Admin-Login vergessen Passwort zurücksetzen

Das Problem beim Zurücksetzen des Passworts für d...

Beispielcode für CSS3 zum Erzielen eines Bildlaufleisten-Verschönerungseffekts

Der spezifische Code lautet wie folgt: /*Breite d...

Detaillierte Erklärung der Transaktionen und Indizes in der MySQL-Datenbank

Inhaltsverzeichnis 1. Angelegenheiten: Vier Haupt...

html Option deaktivieren auswählen auswählen deaktivieren Option Beispiel

Code kopieren Der Code lautet wie folgt: <Ausw...

4 Möglichkeiten, doppeltes Einfügen von Daten in Mysql zu vermeiden

Die gebräuchlichste Methode besteht darin, einen ...