requestAnimationFrame 在何时执行
requestAnimationFrame 是一个 microtask 还是一个 macrotask
setTimeout(() => {
console.log('setTimeout')
}, 0)
requestAnimationFrame(() => {
console.log('requestAnimationFrame')
})
new Promise(r => {
console.log('promise')
r()
}).then(() => console.log('then')
如果是一个 microtask, 那么他应该打印 promise requestAnimationFrame then setTimeout
如果是一个 macrotask, 那么他应该打印 promise then setTimeout requestAnimationFrame
但是实际上有两种可能的打印: promise then requestAnimationFrame setTimeout
和 promise then setTimeout requestAnimationFrame
难道是它既不是一个 macrotask 也不是 microtask ,但是浏览器会在下一帧开始的时候把它加入到 microtask 队列的最前方
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
requestAnimationFrame是一个单回调,和setTimeout差不多
区别是:
setTimeout的时间是你指定的
requestAnimationFrame你不用写时间,它的重绘时间间隔是根据不同浏览器的刷新频率自行脑补的- -所以有严重兼容问题,记得有封装好的处理兼容的函数。