Heim > Web-Frontend > js-Tutorial > Warum gibt „setTimeout' in einer „for'-Schleife den letzten Wert zweimal aus und wie kann ich das beheben?

Warum gibt „setTimeout' in einer „for'-Schleife den letzten Wert zweimal aus und wie kann ich das beheben?

Patricia Arquette
Freigeben: 2025-01-03 22:50:40
Original
706 Leute haben es durchsucht

Why Does `setTimeout` in a `for`-Loop Print the Last Value Twice, and How Can I Fix It?

Aufeinanderfolgende Werteausgabe mit setTimeout in for-Loop

Sie stoßen auf ein Problem, bei dem Sie versuchen, aufeinanderfolgende Werte mit setTimeout zu drucken innerhalb einer for-Schleife, aber es führt dazu, dass der letzte Wert zweimal gedruckt wird. Dies liegt daran, dass, wenn Sie die Variable i direkt in der setTimeout-Funktion verwenden, ihr Wert aktualisiert wird, wenn die Funktion ausgeführt wird. Um dieses Problem zu beheben, ist es wichtig, für jede Iteration eine eigene Kopie von i zu erstellen.

Die bereitgestellte Lösung erreicht dies durch die Deklaration einer Hilfsfunktion namens doSetTimeout. In dieser Funktion wird eine neue Variable deklariert, die den aktuellen Wert von i enthält, der dann beim Erstellen des Timeouts als Argument übergeben wird. Dadurch wird sichergestellt, dass jede Timeout-Funktion über eine eigene Kopie von i verfügt, wodurch Probleme mit Wertaktualisierungen während der Ausführung vermieden werden.

function doSetTimeout(i) {
  setTimeout(function() {
    alert(i);
  }, 100);
}

for (var i = 1; i <= 2; ++i)
  doSetTimeout(i);
Nach dem Login kopieren

Mit dieser Lösung können Sie die aufeinanderfolgenden Werte 1 und 2 wie beabsichtigt erfolgreich drucken.

Das obige ist der detaillierte Inhalt vonWarum gibt „setTimeout' in einer „for'-Schleife den letzten Wert zweimal aus und wie kann ich das beheben?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage