문제:
JavaScript while 루프에 지연을 도입하면 루프가 실행되는 경우가 많습니다. 너무 빠르면 바람직하지 않은 결과가 초래됩니다. 반복 사이의 지연을 포함하는 루프를 어떻게 생성할 수 있습니까?
해결책:
setTimeout() 함수는 지연을 도입하는 데 유용하지만 비차단 기능이며 실행됩니다. 즉시. 결과적으로 루프에서 여러 setTimeout() 호출이 중복됩니다.
대신 재귀 루프 패턴을 활용하여 원하는 효과를 얻을 수 있습니다. 예는 다음과 같습니다.
var i = 1; // Set counter to 1 function myLoop() { // Create loop function setTimeout(function() { // Call 3s setTimeout when loop is called console.log('hello'); // Your code here i++; // Increment counter if (i < 10) { // If counter < 10, call loop function again myLoop(); // Trigger another setTimeout() } }, 3000) } myLoop(); // Start the loop
이 접근 방식에서는 myLoop() 함수가 setTimeout() 콜백 내에서 반복적으로 호출됩니다. 각 반복은 3초씩 지연되어 루프의 순차적 실행을 보장합니다.
위 내용은 반복 반복을 방지하기 위해 JavaScript 루프에 지연을 구현하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!