测试一
我为此专门编写了一个测试:
帧速率分布:setInterval vs requestAnimationFrame
注意:此测试非常占用 CPU。requestAnimationFrame
IE 9- 和 Opera 12- 不支持。
该测试记录 asetInterval
和requestAnimationFrame
在不同浏览器中运行所需的实际时间,并以分布的形式为您提供结果。您可以更改毫秒数setInterval
以查看它在不同设置下的运行情况。对于延迟setTimeout
,其工作方式与 a 类似setInterval
。requestAnimationFrame
通常默认为 60fps,具体取决于浏览器。要查看切换到其他选项卡或使用非活动窗口时会发生什么,只需打开页面,切换到其他选项卡并等待一段时间。它将继续在非活动选项卡中记录这些功能所需的实际时间。
测试二
另一种测试它的方法是使用setInterval
和重复记录时间戳requestAnimationFrame
并在分离的控制台中查看它。当您使选项卡或窗口处于非活动状态时,您可以看到它的更新频率(或是否曾经更新过)。
结果
Chrome
ChromesetInterval
将选项卡处于非活动状态时限制为大约1000ms的最小间隔。如果间隔大于 1000ms,它将以指定的间隔运行。窗口是否失焦并不重要,只有当您切换到不同的选项卡时,间隔才会受到限制。requestAnimationFrame
选项卡处于非活动状态时暂停。
// Provides control over the minimum timer interval for background tabs.
const double kBackgroundTabTimerInterval = 1.0;
https://codereview.chromium.org/6546021/patch/1001/2001
Firefox
类似于Chrome,FirefoxsetInterval
将标签(不是窗口)处于非活动状态时将最小间隔限制为大约1000ms。However, requestAnimationFrame
runs exponentially slower when the tab is inactive, with each frame taking 1s, 2s, 4s, 8s and so on.
// The default shortest interval/timeout we permit
#define DEFAULT_MIN_TIMEOUT_VALUE 4 // 4ms
#define DEFAULT_MIN_BACKGROUND_TIMEOUT_VALUE 1000 // 1000ms
https://hg.mozilla.org/releases/mozilla-release/file/0bf1cadfb004/dom/base/nsGlobalWindow.cpp#l296
Internet Explorer
IE 不会限制setInterval
选项卡处于非活动状态时的延迟,但会requestAnimationFrame
在非活动选项卡中暂停。窗口是否失焦并不重要。
Edge
从 Edge 14 开始,setInterval
在非活动选项卡中的上限为 1000 毫秒。requestAnimationFrame
在非活动选项卡中始终暂停。
Safari
就像Chrome,setInterval
当标签处于非活动状态时,Safari Caps在100毫秒时。requestAnimationFrame
也暂停了。
Opera
自采用 Webkit 引擎以来,Opera 表现出与 Chrome 相同的行为。setInterval
上限为 1000 毫秒,并requestAnimationFrame
在选项卡处于非活动状态时暂停。
概括
非活动选项卡的重复间隔:
setInterval requestAnimationFrame
Chrome
9- 不受影响 不支持
10 不受影响 暂停
11+ >=1000 毫秒暂停
火狐
3- 不受影响 不支持
4 不受影响 1s
5+ >=1000ms 2 n s(n = 自不活动以来的帧数)
IE
9- 不受影响 不支持
10+ 不受影响 暂停
边缘
13-不受影响暂停
14+ >=1000 毫秒暂停
苹果浏览器
5- 不受影响 不支持
6 不受影响 暂停
7+ >=1000 毫秒暂停
歌剧
12- 不受影响 不支持
15+ >=1000 毫秒暂停