JS中多个setTimeOut函数为什么会同时运行?



 <html>
<head>
<script type="text/javascript">
var c=0
var t
function timedCount()
{
document.getElementById('txt').value=c
c=c+1
t=setTimeout("timedCount()",1000)
}
</script>
</head>

<body>
<form>
<input type="button" value="开始计时!" onClick="timedCount()">
<input type="text" id="txt">
</form>
<p>请点击上面的按钮。输入框会从 0 开始一直进行计时。</p>
</body>

</html>

我是前端新手。写了一段计时器的代码。代码如上,为什么多次点击按钮后,计时器速度会加倍,多个setTimeOut函数同时运行?JS不是单线程的吗?

html5 JavaScript

航海♂日志 9 years, 2 months ago

你每点一次,就执行一次timedCount,产生一个新的定时器
你之前设置的定时没有清理掉,导致你的定时器随着你的点击次数的增加而增加

代码修改为:


 <script type="text/javascript">
var t;
function timedCount(continueFlag)
{
    var countEle=document.getElementById('txt');
    var current=parseInt(countEle.value)||0;
    continueFlag = continueFlag||false;
    if(!continueFlag){
        t&&clearTimeout(t);
        countEle.value=0;
    }else{
        countEle.value= current+1;
    }

    t=setTimeout(function(){
        timedCount(true);
    },1000);
}
</script>

一代阿迪王 answered 9 years, 2 months ago

你需要一个变量来存储定时器,就是单例 。
每次点击按钮的时候,先将定时器clear,否则就会不断在内存中产生新的定时器。

clearTimeout(变量)
变量=null

vilinov answered 9 years, 2 months ago

Your Answer