>웹 프론트엔드 >JS 튜토리얼 >반복 반복을 방지하기 위해 JavaScript 루프에 지연을 구현하려면 어떻게 해야 합니까?

반복 반복을 방지하기 위해 JavaScript 루프에 지연을 구현하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-22 22:57:14625검색

How Can I Implement Delays in JavaScript Loops to Prevent Overlapping Iterations?

JavaScript 루프에 지연 구현

문제:

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.