📅  最后修改于: 2023-12-03 15:24:12.736000             🧑  作者: Mango
requestAnimationFrame
(简称 rAF
)是浏览器提供的一种 API,用于优化动画的性能。但有时候,我们需要在动画进行中停止或取消它,这就需要用到 cancelAnimationFrame
(简称 cancelAF
)。
使用 requestAnimationFrame
并保存返回值作为变量:
const animationId = requestAnimationFrame(callback);
然后,在需要停止动画时,调用 cancelAnimationFrame
方法并传入保存的变量:
cancelAnimationFrame(animationId);
cancelAnimationFrame
必须传入 requestAnimationFrame
返回的变量,否则无法停止指定的动画。cancelAnimationFrame
方法。let animationId;
function animate(timestamp) {
// 动画处理逻辑...
animationId = requestAnimationFrame(animate);
}
// 启动动画
animationId = requestAnimationFrame(animate);
// 停止动画
cancelAnimationFrame(animationId);
在熟练使用 requestAnimationFrame
的同时,能够熟练使用 cancelAnimationFrame
可以更好地掌控动画的运行状态,提高交互体验。