JS 中,window 对象的 requestAnimationFrame 是什么?

108 阅读1分钟

window 提供一个 API,优化动画的执行。

语法:

const id = window.requestAnimationFrame(callback);

传入一个回调函数 callback,在下一次重绘的时候执行。

浏览器重绘频率一般是60 fps(frame per second),也就是一秒钟执行60帧动画。

它的优点有:

  1. 执行流畅。requestAnimationFrame 执行时间和重绘频率一致,相当于自带函数节流功能。
  2. 执行准确。浏览器重绘频率定好的,不会像 setTimeout 需要主流程执行完毕再执行。
  3. 性能优化。在页面 hidden 的情况下,requestAnimationFrame 不会执行,节省性能。

取消 requestAnimationFrame

window.cancelAnimationFrame(id)

Reference

[1] developer.mozilla.org/en-US/docs/… [2] blog.csdn.net/xuanhun521/…