当前位置: 首页 > news >正文

前端如何实现一个高精准定时器和延时器

一、为什么浏览器定时器不精准?

1️⃣ JS 是单线程

  • 主线程被占用 → 定时器回调延迟

  • UI / 渲染 / GC 都会阻塞


2️⃣ 浏览器最小时间精度限制

  • HTML5 规范限制(4ms)

  • 后台 Tab 被强制降频(1000ms+)


3️⃣ setInterval 的“时间漂移”

setInterval(fn, 1000); // 实际执行时间 = 1000 + fn执行时间

👉时间会越来越不准


二、高精准定时器的核心思想(先记住)

不用“执行次数”计时,而用“时间戳”对齐真实时间。


三、高精准延时器(setTimeout 替代方案)⭐

实现:时间戳校正法

function preciseTimeout(fn, delay) { const start = performance.now(); function loop() { const now = performance.now(); if (now - start >= delay) { fn(); } else { requestAnimationFrame(loop); } } loop(); }

为什么准?

  • 使用高精度时钟performance.now()

  • 每帧校正误差


四、高精准定时器(setInterval 替代方案)⭐⭐

实现:递归 setTimeout + 时间修正

function preciseInterval(fn, interval) { let expected = performance.now() + interval; function step() { const drift = performance.now() - expected; fn(); expected += interval; setTimeout(step, Math.max(0, interval - drift)); } setTimeout(step, interval); }

核心点

  • 不是简单等待 interval

  • 每次都修正漂移


五、Web Worker 定时器(更准)🚀

为什么 Worker 更准?

  • 不阻塞 UI 线程

  • 不受页面渲染影响


worker.js

setInterval(() => { postMessage(Date.now()); }, 1000);

主线程

const worker = new Worker('worker.js'); worker.onmessage = () => { console.log('tick'); };

👉计时类、音频、监控系统首选


六、requestAnimationFrame 方案(适合动画)

let last = performance.now(); function rafTimer() { const now = performance.now(); if (now - last >= 1000) { console.log('tick'); last = now; } requestAnimationFrame(rafTimer); } rafTimer();

七、三种方案对比(面试必背)

方案精度适合场景
setTimeout普通任务
时间校正业务定时
Web Worker很高长期计时
RAF动画 / UI

八、延时器 vs 定时器(概念区分)

类型特点
延时器执行一次
定时器周期执行
高精准基于时间差

九、后台 / 锁屏问题(高级)

问题

  • 浏览器后台 Tab 会降频

解决方案

  • Web Worker

  • Visibility API + 校正

  • 服务端时间对齐


十、30 秒面试标准回答(直接背)

浏览器原生定时器会因主线程阻塞产生时间漂移;
高精准定时器应基于时间戳校正,而不是固定间隔;
可以通过递归 setTimeout、requestAnimationFrame 或 Web Worker 提升精度;
对精度要求极高的场景应使用 Worker 或服务端时间同步。


http://www.jsqmd.com/news/287815/

相关文章:

  • Qwen3-0.6B调用示例:LangChain与OpenAI接口兼容演示
  • 2026值得关注的点胶机超声波流量传感器品牌推荐
  • 为什么DeepSeek-R1适合中小企业?低成本部署实证分析
  • NewBie-image-Exp0.1如何调用API?create.py交互脚本二次开发指南
  • 5个开源大模型镜像推荐:MinerU免配置一键部署教程
  • 用测试镜像轻松实现服务开机自启,无需复杂命令
  • 2026年精选冷却系统超声波流量传感器品牌推荐
  • 适配多样工况:2026年优选冷却水超声波流量计品牌推荐
  • 详细介绍:openEuler WSL嵌入式开发环境搭建:ARM交叉编译工具链配置全攻略
  • Qwen_Image_Cute_Animal_For_Kids省钱实战:免费镜像+按需GPU计费
  • 赋能工业自动化生产:2026超声波流量传感器品牌推荐
  • 小白也能懂的verl教程:轻松实现LLM后训练实战
  • Qwen3-1.7B离线语音助手搭建全过程
  • LoRA微调支持吗?Live Avatar扩展性分析
  • 大爱[特殊字符]Jinger
  • Qwen1.5-0.5B部署避坑:文件损坏404问题终极解决
  • CSDNtoupiao
  • Qwen3-4B-Instruct部署教程:支持256K上下文的完整指南
  • 告别繁琐配置!PyTorch-2.x镜像让深度学习项目秒速启动
  • 手把手教你用gpt-oss-20b-WEBUI实现AI角色对话
  • 提升修复质量:fft npainting lama边缘羽化参数调整指南
  • verl在电商客服中的应用,效果惊艳
  • Llama3-8B支持16k上下文?外推方法实测部署教程
  • MinerU学术数据库建设:文献统一格式转换方案
  • fft npainting lama能否去除大面积物体?实测填充逻辑
  • 通义千问3-14B显存溢出?14GB FP8版本部署成功案例
  • Qwen2.5-0.5B如何实现低延迟?架构优化部署详解
  • 一个人的管理水平,开一场会就知道了
  • 想做人像抠图?试试这个预装环境的BSHM镜像
  • 小白也能懂的verl教程:快速部署LLM后训练框架