已經開始無限計數后再次點擊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 故越來越快