首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >requestAnimationFrame是否在微型化之间运行?

requestAnimationFrame是否在微型化之间运行?
EN

Stack Overflow用户
提问于 2022-08-24 17:49:58
回答 1查看 53关注 0票数 1

假设我们有一个60赫兹的刷新率,当浏览器完成画图时,应该以这个频率运行动画帧。如果浏览器执行多个微任务,并且它们(集体)占用超过1/60秒,而在该时间之后,微任务队列仍然不是空的,那么在此期间它会运行requestAnimationFrame回调吗?还是会阻止此回调直到微任务队列为空?换句话说:requestAnimationFrame回调可以在执行非空微任务队列的微任务之间运行吗?

如果答案是肯定的,那么我可以假设,当我的应用程序运行大量的微任务时,requestAnimationFrame可以是提高应用程序响应性的一个好方法,对吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-08-24 18:09:41

做一个简单的例子证明requestAnimationFrame会等待

代码语言:javascript
运行
复制
const maxLoops = 10000000
let loopCount = 0

async function loop() {
  loopCount += 1
  if (loopCount >= maxLoops) return 'yes'
  return Promise.resolve().then(loop)
}


Promise.resolve()
  .then(() => loop())
  .then(r => console.log('done', r))
  .catch(console.error)

requestAnimationFrame(() => console.log('animation frame'))

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73477611

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档