setInterval()
Window
및 Worker
인터페이스에서 제공되는
setInterval()
메서드는 각 호출 사이에 고정된 시간 지연으로
함수를 반복적으로 호출하거나 코드 스니펫을 실행합니다.
이 메서드는 간격(interval)을 고유하게 식별할 수 있는 interval ID를 반환하므로 나중에 clearInterval()
함수를 호출하여 제거할 수 있습니다.
구문
setInterval(code)
setInterval(code, delay)
setInterval(func)
setInterval(func, delay)
setInterval(func, delay, arg0)
setInterval(func, delay, arg0, arg1)
setInterval(func, delay, arg0, arg1, /* … ,*/ argN)
매개변수
func
-
delay
(밀리초)마다 실행되는function
입니다. 첫 번째 실행은delay
(밀리초) 후에 발생합니다. code
-
선택적 구문을 사용하면 함수 대신 문자열을 포함할 수 있습니다. 모든
delay
(밀리초)마다 컴파일되고 실행됩니다. 이 구문은eval()
을 사용하는 것과 같은 이유로 보안상 위험하므로 "권장하지 않습니다". delay
Optional-
타이머가 지정된 함수 또는 코드 실행 사이에 지연해야 하는 밀리초(1/1000초) 단위의 시간입니다. 지정하지 않으면 기본 값은 0입니다.
delay
값의 허용 범위에 대한 자세한 내용은 아래의 지연 제한을 참조하세요. arg0, …, argN
Optional-
타이머가 만료되면 func 에서 지정한 함수로 전달되는 추가 인수입니다.
반환 값
반환된 intervalID
는 setInterval()
호출로 생성된, 타이머를 식별하는 0이 아닌 숫자 값입니다.
이 값은 clearInterval()
에 전달되어 interval을 취소할 수 있습니다.
setInterval()
및 setTimeout()
은 동일한 ID 풀을 공유하고 clearInterval()
및
clearTimeout()
은 기술적으로 상호 교환하여 사용할 수 있음을
알고 있으면 도움이 될 수 있습니다.
그러나 명확성을 위해 코드를 유지 관리할 때 혼동을 피하기 위해 항상 일치하도록 노력해야 합니다.
Note:
delay
인수는 부호 있는 32-bit 정수로 변환됩니다. 이는 IDL에서 부호 있는 정수로 지정되기 때문에delay
를 2147483647 ms로 효과적으로 제한합니다.
예제
예제 1: 기본 구문
다음 예제는 setInterval()
의 기본 구문을 보여줍니다.
const intervalID = setInterval(myCallback, 500, "Parameter 1", "Parameter 2");
function myCallback(a, b) {
// 여기에 코드를 작성하세요
// 매개변수는 순전히 선택적입니다.
console.log(a);
console.log(b);
}
예제 2: 두 가지 색상 변환하기
다음 에제는 중지 버튼을 누를 때까지 1초에 한 번씩 flashtext()
함수를 호출합니다.
HTML
<div id="my_box">
<h3>Hello World</h3>
</div>
<button id="start">Start</button>
<button id="stop">Stop</button>
CSS
.go {
color: green;
}
.stop {
color: red;
}
JavaScript
// intervalID를 저장할 변수입니다
let nIntervId;
function changeColor() {
// 간격이 이미 설정되어 있는지 확인합니다
if (!nIntervId) {
nIntervId = setInterval(flashText, 1000);
}
}
function flashText() {
const oElem = document.getElementById("my_box");
oElem.className = oElem.className === "go" ? "stop" : "go";
}
function stopTextColor() {
clearInterval(nIntervId);
// 변수에서 intervalID를 해체합니다
nIntervId = null;
}
document.getElementById("start").addEventListener("click", changeColor);
document.getElementById("stop").addEventListener("click", stopTextColor);
결과
같이 보기: clearInterval()
"this" 문제
메서드를 setInterval()
또는 다른 함수에 전달하면 잘못된
this
값으로 호출됩니다.
이 문제는 JavaScript reference에서 자세히 설명합니다.
설명
setInterval()
에 의해 실행되는 코드는 호출된 함수와 별도의 실행 컨텍스트에서
실행됩니다. 결과적으로 호출된 함수의 this
키워드는 window
(또는 global
) 객체로 설정되며 setTimeout
을 호출한 함수의 this
값과
동일하지 않습니다. setTimeout()
대신 setInterval()
을 사용하여
다음 예제를 참조하세요(사실 문제는 두 타이머 모두 동일합니다)
myArray = ["zero", "one", "two"];
myArray.myMethod = function (sProperty) {
alert(arguments.length > 0 ? this[sProperty] : this);
};
myArray.myMethod(); // "zero,one,two"가 출력됩니다
myArray.myMethod(1); // "one"가 출력됩니다
setTimeout(myArray.myMethod, 1000); // 1초 후 "[object Window]"가 출력됩니다
setTimeout(myArray.myMethod, 1500, "1"); // 1,5초 후에 "undefined"가 출력됩니다
// myArray.myMethod 내에서 this의 값을 변경하려는 동안
// setTimeout 내부에서 this의 값을 변경하기 때문에
// .call과 함께 'this'객체를 전달하는 것은 동작하지 않습니다
// 사실 setTimeout 코드는 this가 window 객체가 될 것으로 예상하기 때문에 오류가 발생합니다
setTimeout.call(myArray, myArray.myMethod, 2000); // error: "NS_ERROR_XPC_BAD_OP_ON_WN_PROTO: Illegal operation on WrappedNative prototype object"
setTimeout.call(myArray, myArray.myMethod, 2500, 2); // 위와 동일한 에러가 발생합니다
보시다시피 레거시 JavaScript에서는 this
객체를
콜백 함수에 전달할 방법이 없습니다.
가능한 해결 방법
모든 최신 JavaScript 런타임(브라우저 및 기타)은 lexical this
를 사용하여 화살표 함수를 지원합니다. myArray
메서드 내부에 있는 경우 setInterval(() => this.myMethod())
를 작성할 수 있습니다.
IE를 지원해야 하는 경우 지정된 함수의 모든 호출에 this
의 값을 고정할 수 있는 Function.prototype.bind()
메서드를 사용하세요. 이렇게 하면 함수가 호출된 컨텍스트에 따라 this
가 무엇인지 명확하지 않은 문제를 쉽게 우회할 수 있습니다.
사용 일람
setInterval()
함수는 일반적으로 애니메이션과 같이 반복해서 실행되는 함수의
지연을 설정하는 데 사용됩니다. clearInterval()
을 사용하여
interval을 취소할 수 있습니다.
지정된 지연 후 함수를 "한번" 호출하려면 setTimeout()
를
사용하세요.
지연 제한
간격(interval)은 중첩될 수 있습니다. 즉, setInterval()
에 대한 콜백이
setInterval()
을 호출하여 첫 번째 간격이 계속 진행 중일지라도
다른 간격의 실행을 시작할 수 있습니다. 이것이 성능에 미칠 수 있는 잠재적인
영향을 완화하기 위해 간격이 5개 수준 이상으로 중첩되면 브라우저는 자동으로
간격에 대해 4 ms 최소 값을 적용합니다. 중첩 호출이 심화된 setInterval()
의
호출에서 4 ms 미만의 값을 지정하면 4 ms로 고정됩니다.
브라우저는 일부 상황에서 간격에 대해 훨씬 더 엄격한 최소 값을 적용할 수
있지만 이러한 경우는 일반적이지 않아야 합니다. 또한 콜백 호출 사이의 실제 경과 시간은
주어진 delay
보다 길 수 있습니다.
더 많은 예제는 지정된 값보다 더 오래 지연되는 이유를 참고하세요.
실행 시간이 간격 빈도보다 짧은지 확인
로직 실행 시간이 간격 시간보다 오래 걸릴 가능성이 있는 경우
setTimeout()
을 사용하여 명명된 함수를 재귀적으로 호출하는
것이 좋습니다. 예를 들어 setInterval()
을 사용하여 5초마다 원격 서버를
폴링하는 경우 네트워크 대기 시간, 응답하지 않는 서버 및 기타 여러 문제로 인해
요청이 할당된 시간 내에 완료되지 않을 수 있습니다. 따라서 반드시 순서대로
반환되지 않는 대기 중인 XHR 요청이 있을 수 있습니다.
이러한 경우 재귀적인 setTimeout()
패턴이 선호됩니다.
(function loop() {
setTimeout(() => {
// 로직을 넣어주세요
loop();
}, delay);
})();
위 스니펫에서 명명된 함수 loop()
가 선언되고 즉시 실행됩니다.
loop()
는 로직이 실행된 후 setTimeout()
내에서 재귀적으로
호출됩니다. 이 패턴은 고정 간격에서의 실행을 보장하지 않지만
이전 간격이 재귀하기 전에 완료되었음을 보장합니다.
명세
Specification |
---|
HTML Standard # dom-setinterval-dev |
브라우저 호환성
BCD tables only load in the browser