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()多次运行函数后越来越快的问题的主要内容,如果未能解决你的问题,请参考以下文章