gpt4 book ai didi

javascript - jquery 倒数计时器 NaN

转载 作者:行者123 更新时间:2023-12-03 11:55:11 25 4
gpt4 key购买 nike

嗨,我是 JS 和 jQuery 的新手,我对简单的倒计时器有疑问。

当我在输入中输入一些值时,它会在倒计时器中转换为 NaN(而不是数字)。

这是我的代码:

$(function() {
var $input = $('#time'),
seconds = parseInt($input.val()),
$start = $('button');

$start.on('click', function() {
var interval = setInterval(function() {

switch (seconds) {
case 0:
clearInterval(interval);
console.log("Time's UP!");
break;
case 1:
console.log("Do końca pozostała " + seconds + " sekunda"); /*polish gramaticall variation*/
break;
case 4:
case 3:
case 2:
console.log("Do końca pozostało " + seconds + " sekundy"); /*polish gramaticall variation*/
break;
default:
console.log("Do końca pozostało " + seconds + " sekund"); /*polish gramaticall variation*/
}
seconds = seconds - 1;
}, 1000);
});
});

HTML:

<label for="time">Set time in seconds </label>
<input type="text" id="time">
<button>Start</button>

最佳答案

您仅在 document.ready 上分配 seconds 的值,因此它的初始值只有 "" - 其中解析为 NaN。将其移至 .click 处理程序中,以便每次单击按钮时都会更新秒数:

var seconds = 0;
$start.on('click', function(){
seconds = parseInt($input.val(), 10); // Always pass a radix to parseInt
....
});

jsFiddle

关于javascript - jquery 倒数计时器 NaN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25638482/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com