其他分享
首页 > 其他分享> > setTimeout 模拟setInterval

setTimeout 模拟setInterval

作者:互联网

 

当我们使用setInterval函数来实现间隔一段时间执行一段代码的时候,

如果回调函数花费的时间远大于时间间隔,那么就不会在规定时间间隔执行回调函数,

因为JavaScript的运行机制是先清空执行栈里面的任务,如果执行栈空了,然后去任务队列里面取出任务放到执行栈执行,也就是所谓的js的eventloop, 事件循环机制,

而如果setInterval 中的任务耗费时间太长,那么就会一直阻塞执行栈,任务队列里面的任务就无法按照时间去执行;

所以需要用setTimeout模拟setInterval

 

 

function newInterval(func, millisecond){
  function inside(){
      func();
      setTimeout(inside, millisecond)
  }
  setTimeout(inside, millisecond)
}

 

标签:millisecond,setTimeout,setInterval,inside,任务,执行,模拟
来源: https://www.cnblogs.com/qqfontofweb/p/16446767.html