JavaScript에서 setTimeout() 함수는 지정된 밀리초 후에 함수가 실행되도록 예약합니다. 그러나 코드 실행을 중단하지는 않습니다. 즉, 지정된 지연 시간에 관계없이 setTimeout() 호출 직후 다음 코드 줄이 실행됩니다.
귀하의 코드는 newState가 -1인지 확인하기 전에 5초 동안 기다리는 것을 목표로 합니다. 그러나 setTimeout()은 코드를 차단하지 않으므로 5초 지연이 발생하기 전에 즉시 검사가 수행됩니다.
원하는 동작을 달성하려면 메커니즘을 사용해야 합니다. 5초 동안 코드 실행을 일시 중지할 수 있습니다. 고려할 수 있는 두 가지 현대적인 접근 방식이 있습니다.
ES6에서는 비동기 코드를 보다 동기적인 스타일로 작성할 수 있는 async/await 구문을 도입했습니다. 함수를 비동기로 표시하면 wait 키워드를 사용하여 약속이 해결될 때까지 실행을 일시 중지할 수 있습니다.
<code class="javascript">const delay = ms => new Promise(resolve => setTimeout(resolve, ms)); const stateChange = async newState => { await delay(5000); if (newState === -1) { alert('VIDEO HAS STOPPED'); } };</code>
Node.js 16에서 타이머/약속 모듈은 setTimeout의 약속 기반 버전을 제공합니다. 이를 통해 실행을 일시 중지하고 계속하기 전에 지연이 완료될 때까지 기다릴 수 있습니다.
<code class="javascript">import { setTimeout } from "timers/promises"; const stateChange = async newState => { await setTimeout(5000); if (newState === -1) { console.log('VIDEO HAS STOPPED'); } };</code>
이 두 접근 방식 모두 newState 검사가 수행되기 전에 코드 실행이 5초 동안 중지되도록 보장합니다.
위 내용은 JavaScript에서 다음 줄을 실행하기 전에 5초를 기다리는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!