> 웹 프론트엔드 > JS 튜토리얼 > 내 setInterval 콜백 함수가 한 번만 실행되는 이유는 무엇입니까?

내 setInterval 콜백 함수가 한 번만 실행되는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-07 00:44:12
원래의
212명이 탐색했습니다.

Why Does My setInterval Callback Function Only Execute Once?

setInterval 콜백 함수 한 번 실행: 해결

이 시나리오에서는 카운터가 무기한 실행됩니다. 단순화된 버전을 살펴보겠습니다.

function timer() {
  console.log("timer!");
}

window.setInterval(timer(), 1000);
로그인 후 복사

그러나 이 구현은 예상치 못한 결과를 낳습니다. "타이머" 메시지는 한 번만 나타납니다.

문제는 setInterval의 첫 번째 인수에 있습니다. 함수 참조(타이머)를 제공하는 대신 코드가 실수로 함수(타이머())를 실행하고 있습니다. 이는 다음과 같이 수정할 수 있습니다.

window.setInterval(timer, 1000);
로그인 후 복사

또는 더 간결하지만 읽기 어려운 구문을 사용할 수 있습니다.

window.setInterval(function() {
  console.log("timer!");
}, 1000);
로그인 후 복사

이러한 수정 사항을 구현하면 이제 카운터가 실행됩니다. 의도한 기능을 지속적으로 수행합니다.

위 내용은 내 setInterval 콜백 함수가 한 번만 실행되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿