Javascriptで秒数をカウントダウンしようとしています。
ここに私のHTMLがあります
<div id="ban_container" class="error center">Please wait
<span id="ban_countdown" style="font-weight:bold">
45</span>
seconds before trying again
</div>
そして私のJS:
<script type="text/javascript">
var seconds = <?php echo $user->getBlockExpiryRemaining(); ?>;
function countdown(element) {
var el = document.getElementById(element);
if (seconds === 0) {
document.getElementById("ban_container").innerHTML = "done";
return;
}
else {
el.innerHTML = seconds;
seconds--;
setTimeout(countdown(element), 1000);
}
}
countdown('ban_countdown');
</script>
ただし、何らかの理由で、タイムアウト時間を待っているのではなく、countdown
すぐに実行されるため、ページを更新するとすぐに「完了」と表示されます。実際に複数回実行されていることはわかっています。実行するinnerHTML += seconds + " ";
と 45 からカウントダウンされるためです。タイムアウトがバイパスされるのはなぜですか?