这篇文章将为大家详细讲解有关浏览器中如何实现JavaScript计时器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
在 Web Worker中使用无限同步循环
由于 Web Worker 本质上是Web线程,因此你可以在其中无限循环而不阻塞主线程。这使你可以访问微秒级的时间分辨率。这对于在 Worker 中做出时间关键的决策是特别实用的,可以让主线程准确的知道什么时候合适。例如:只要微秒是质数,就渲染某些东西。要访问微秒,你可以使用 performance.now。

优点
引用MDN:“ Worker 的 Terminate() 方法立即终止 Worker。它不会为等待 Worker 完成里面执行的程序,而是会立即停止。”
缺点
使用CSS动画处理时间事件(animationiteration)
如果创建带有无限动画的 div。你可以订阅其 animationiteration 事件,并在事件 animation-duration 回调时得到通知。

优点
自动暂停时,标签不在焦点。当标签不在焦点上时,事件根本不会触发。无需担心调用时卡住,这些调用将在再次显示选项卡时立即运行。
从 DOM 中删除隐藏的 div 时,将自动进行清理。例如,如果你有一个可渲染时间的 React 组件,则无需在卸载时做任何事情。该 div 将被删除,该事件将不再触发。
调用逻辑很优雅:.addEventListener("animationiteration", fun)。
超级干净的方法来延迟启动计时器:animation-delay。
缺点
使用SVG 标签(SMIL动画)

<svg> <rect> <animate attributeName="rx" values="0;1" dur="1s" repeatCount="indefinite" /> </rect> </svg>
如果这样调用:animate.addEventListener('repeat', fun),你的函数将每秒被调用一次。
优点
缺点
有点太聪明了,可能会使你的协作者感到困惑。
取决于 DOM 和 CSSOM 。与上述相同的警告。其他CSS规则可能会干扰你的配置。
IE 和 Edge (在 Chromium 之前)不受支持。
不准确 根据我的测试,它可能会延迟15ms。
直到整页加载才开始。是的,可能是一个缺点,但是也是一个功能。
使用 Web Animations API

Web Animations API 允许你在 JavaScript 中为 DOM 元素设置动画。
有趣的是,你可以使未渲染完的元素具有动画效果!这使你能够访问纯 JS (和 Web api)中的定时机制。
这是替代 setTimeout 的实现:
function ownSetTimeout(callback, duration) { const div = document.createElement('div'); const keyframes = new KeyframeEffect(div, [], { duration, iterations: 1 }); const animation = new Animation( keyframes, document.timeline ); animation.play(); animation.addEventListener('finish', () => { callback(); }); }
很整洁,不是吗?
优点
不需要DOM交互。
不熟悉的人容易理解。
标签未聚焦时自动暂停。
缺点
关于“浏览器中如何实现JavaScript计时器”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。