不懂就问,用 setTimeout 简单实现 setInterval 的问题

发布于 2022-09-12 23:06:51 字数 379 浏览 8 评论 0

代码如下

  let timer;
  const _setInterval = (cb, time) => {
    timer = setTimeout(() => {
      cb()
      _setInterval(cb, time)
    }, time)
  }

  _setInterval(() => {
    console.log('count')
  }, 1000)

  setTimeout(() => {
    clearTimeout(timer)
  }, 3001)

我设置清除定时器的时长是 3001ms
但是为什么这段代码 还是只打印了两次 count 啊 不应该是三次吗~有没有大佬分析一波

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

寒江雪… 2022-09-19 23:06:51

如果把输出写得详细一点,加上时间信息

    let timer;
    const _setInterval = (cb, time) => {
        timer = setTimeout(() => {
            cb()
            _setInterval(cb, time)
        }, time);
    }

    _setInterval(() => {
        const now = Date.now();
        console.log('count', now, now - start);
    }, 1000)

    setTimeout(() => {
        clearTimeout(timer)
    }, 3001);

    const start = Date.now();
    console.log("start: ", start);

会发现输出并不是精确的 1000 毫秒延时

start:  1617522317036
count 1617522318045 1009
count 1617522319051 2015

用原生的 setInterval() 会更准确一些(因为模拟的 cb() 处理业务会花一些时间),但仍然可能会有非常小的误差的。

心舞飞扬 2022-09-19 23:06:51

JS 里的定时器也依赖 event loop,并不是严格按照时间。所以虽然支持你用 ms 设置定时器,但什么时候触发其实不一定。所以建议至少以 10ms 为标准,也不要让不同定时器互相影响。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文