我正在尝试使用 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 开始倒计时。为什么会绕过超时?