SetTimeout()多次运行函数后越来越快的问题

Posted dreamice

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SetTimeout()多次运行函数后越来越快的问题相关的知识,希望对你有一定的参考价值。

问题原因很简单,但是由于代码逻辑问题,一直没有考虑到;

网上有个帖子说的很明白:原帖入口

假如你在0时刻点击了一下按钮,那么500ms时数字会跳一下,1000ms会再跳一下,依次类推,1500,2000,2500.....的时候都会跳一下,时间间隔始终是500ms,但是,假如你在300ms的时候又点击了一下按钮,那么800ms的时候数字就会跳一下,1300,1800,2300.....的时侯都会跳一下,那么现在看0到2000ms之间,300,500,800,1000,1300,1500,1800,2000时刻时数字都会跳一下,数字变化的时间间隔自然会变小,同理,你点击的次数越多,时间间隔就会越小。

你每点击一次都会创建一个新的定时器,但是之前的定时器不会自己取消。

你要在创建新的定时器前用clearTimeout()取消之前的定时器。

 

解决:创建新的定时器前用clearTimeout()取消之前的定时器。



以上是关于SetTimeout()多次运行函数后越来越快的问题的主要内容,如果未能解决你的问题,请参考以下文章

运行越来越快的Java热点代码

setTimeout()

setTimeout() 只运行一次,当被多次调用时

setTimeout与setInterval

setTimeout和setInterval的区别

setTimeout()和setInterval() 何时被调用执行(非多线程).RP