随笔 - 148  文章 - 0  评论 - 13  阅读 - 21万

为什么要用setTimeout模拟setInterval?

一 setInterval的时间误差

  setInterval(fn,300);

setInterval 执行机制,300ms会检测一次任务队列中有无未执行的上一次任务fn,如果没有则将fn加入任务队列,如果有则跳过。由于js单线程,如果在执行fn前还要耗时的任务执行,则会暴露缺点
1.某些间隔会被跳过
2.可能多个定时器会连续执行

setTimeout 执行机制

  setTimeout(fn,300);

每隔300ms会将fn加入到任务队列中。

二 用setTimeout 模拟 setInterval

1.利用setTimeout能解决 间隔会被跳过缺点
2.利用递归调用setTimeout 能解决多个定时器连续执行的缺点,确保执行fn的间隔时间>=300ms;由于js单线程,只能保证每隔300将fn加入到任务队列,fn执行的时机与任务队列中的其他任务是否执行完毕有关。

  class Poll{
    constructor(){
      this.clearTime = null;
    }
    setInter(fn,time){
      this.clearTime = setTimeout(()=>{
        fn();
        this.setInter(fn,time);
      },time)
    }
    clearInter(){
      if(this.clearTime){
        clearTimeout(this.clearTime);
      }
    }
  }
posted on   长安城下翩翩少年  阅读(247)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示