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

So erstellen Sie https mit Nginx und dem kostenlosen Tencent Cloud-Zertifikat

Ich habe gelernt, wie man https bekommt. Kürzlich...

Prozess des Klassenlademechanismus von Tomcat und Quellcodeanalyse

Inhaltsverzeichnis Vorwort 1. Strukturdiagramm de...

MySQL 8.0.12 – Schnellinstallations-Tutorial

Die Installation von MySQL 8.0.12 dauerte zwei Ta...

Mac+IDEA+Tomcat-Konfigurationsschritte

Inhaltsverzeichnis 1. Herunterladen 2. Installati...

CSS3 erzielt einen coolen 3D-Rotationsperspektiveneffekt

CSS3 erreicht coole 3D-Rotationsperspektive 3D-An...

Die Tücken der automatischen Inkrementierung numerischer MySQL-Typen

Beim Entwurf von Tabellenstrukturen gehören numer...

So verwenden Sie Nginx, um einen RTMP-Liveserver auszuführen

Dieses Mal haben wir einen RTMP-Liveübertragungss...

Verschiedene Arten von MySQL-Indizes

Was ist ein Index? Ein Index ist eine Datenstrukt...

Detaillierte Erläuterung des Vue Router Routing Guard

Inhaltsverzeichnis 1. Global vor jedem 1. Global ...