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

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

Susan Sarandon
Susan Sarandon원래의
2024-12-07 00:44:12195검색

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

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