已經開始無限計數后再次點擊start按鈕,計數會從原來的1s間隔變快,每多點一次就跳動的更快,這是為什么呀
<!DOCTYPE?HTML>
<html>
<head>
<meta?http-equiv="Content-Type"?content="text/html;?charset=utf-8">
<title>計時器</title>
</head>
<script?type="text/javascript">
??var?num=0;
??function?startCount()?{
????document.getElementById('count').value=num;
????num=num+1;
????setTimeout(startCount,1000);
??}
</script>
</head>
<body>
<form>
<input?type="text"?id="count"?onclick="startCount()"/>
<input?type="button"?value="start"?onclick="startCount()"/>
</form>
</body>
</html>
2015-09-01
setTimeout(function(){
},1000); ? setTimeout內的方法是異步調用的,相當于開辟了新的線程,它一直在這個新線程里執行(每秒給num+1),你每多點一次就多了一個新線程在做這個操作,所以你覺得是快了(其實不是快了而是你每秒加的不是1而是你點了幾次就是每秒加了幾次),你可以這樣寫來清除一個setTimeout,var timer1 = setTimeout(funciton(){//一系列操作},1000); ?clearTimeout(timer1);這樣一來就相當于關閉timer1的線程,終止它不再執行。
2015-10-16
點了很多次start后, 就多了很多個timer, 而clearTimeout只能清除對應的timer, 要想全部清除點很多次start后生成的timer, 有啥子辦法呢?
2015-09-01
2015-08-29
我也是這塊不太懂,還是沒理解
2015-08-27
點一次就多了一個 timer及(setTimeout()),點2次就會把num在1000毫秒加2 故越來越快