0

0

javascript动画如何实现_如何使用requestAnimationFrame创造流畅动画【教程】

狼影

狼影

发布时间:2026-02-02 20:20:56

|

925人浏览过

|

来源于php中文网

原创

requestAnimationFrame 是实现流畅动画的唯一合理选择,因其与屏幕刷新率同步、后台自动暂停、无强制延迟抖动;需用时间戳计算 deltaTime 保证跨设备速度一致,避免混用 CSS 动画时的跳变。

javascript动画如何实现_如何使用requestanimationframe创造流畅动画【教程】

requestAnimationFrame 是实现流畅 JavaScript 动画的唯一合理选择,setTimeout/setInterval 本质无法匹配屏幕刷新节奏,必然掉帧或卡顿。

为什么 requestAnimationFrame 比 setTimeout 更适合动画

浏览器在每次重绘前会主动调用 requestAnimationFrame 回调,它天然与显示器刷新率(通常是 60Hz)同步;而 setTimeout 只能“尽力”按毫秒间隔执行,实际触发时间受 JS 主线程阻塞、任务队列延迟等影响,容易累积误差。更关键的是:页面切到后台时,requestAnimationFrame 会被自动暂停,setTimeout 却照常运行,浪费资源甚至导致切回前台时动画突进。

  • 不手动控制帧率 —— 浏览器决定何时执行,你只负责“下一帧该干什么”
  • 自动节流 —— 隐藏标签页、系统节能模式下自动降频或暂停
  • 无强制延迟抖动 —— 不像 setTimeout(fn, 16) 实际可能延后 2–5ms

最简可用的 requestAnimationFrame 动画循环结构

核心是递归调用自身,并在每次回调中更新状态 + 渲染。别漏掉“停止条件”,否则无限执行:

let animationId = null;
const animate = () => {
  // 更新逻辑:比如 this.x += this.speed
  update();
  // 渲染逻辑:比如 element.style.transform = `translateX(${this.x}px)`
  render();
  // 关键:下一次重绘前继续调用
  animationId = requestAnimationFrame(animate);
};
// 启动
animationId = requestAnimationFrame(animate);
// 停止(例如离开页面或动画完成)
// cancelAnimationFrame(animationId);
  • 必须把 requestAnimationFrame 的返回值存起来,才能后续用 cancelAnimationFrame 中断
  • 不要在回调里直接写 requestAnimationFrame(animate) 而不赋值 —— 这会导致无法取消
  • 更新(update)和渲染(render)应尽量轻量;重计算放 Web Worker,DOM 操作批量做

如何处理不同设备刷新率下的时间一致性

requestAnimationFrame 回调函数会接收一个高精度时间戳(DOMHighResTimeStamp),单位毫秒,从页面加载开始计时。用它计算真实经过时间,可让动画速度不随帧率浮动:

Midjourney
Midjourney

当前最火的AI绘图生成工具,可以根据文本提示生成华丽的视觉图片。

下载

立即学习Java免费学习笔记(深入)”;

let lastTime = 0;
const animate = (currentTime) => {
  const deltaTime = currentTime - lastTime;
  lastTime = currentTime;

// 例如:每秒移动 100px,则这一帧应移动 (100 deltaTime / 1000) px this.x += this.speed deltaTime / 1000;

render(); requestAnimationFrame(animate); };

  • 不用 Date.now() —— 它精度低,且不受浏览器节流策略保护
  • 避免用固定增量(如 this.x += 2)—— 在 30Hz 屏幕上会慢一半
  • 如果动画需严格帧数控制(如 24fps 过场),仍需用时间戳做采样过滤,而非硬等帧

常见踩坑:CSS 动画 vs JS 动画的边界在哪

不是所有动效都该用 requestAnimationFrame 手写。浏览器对 CSS transform/opacity 的动画做了硬件加速和合成层优化,性能远超 JS 操控 style;而 JS 适合做需要动态逻辑判断的动画(比如跟随鼠标、物理模拟、数据驱动形变)。混用时尤其注意:

  • CSS 动画正在运行时,JS 直接改 element.style.transform 会强行中断 CSS 动画并覆盖,造成跳变
  • getComputedStyle 读取 transform 值再解析 —— 成本高,且返回的是 matrix,非原始值
  • 想用 JS 控制但保留 CSS 加速?优先用 transform: translateZ(0)will-change: transform 提前升层,再用 requestAnimationFramestyle.transform

真正难的不是写循环,而是判断该不该用它、怎么跟 CSS 协同、以及如何让时间计算不漂移 —— 这些细节没处理好,60fps 的承诺就只是幻觉。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

546

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

546

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

266

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

361

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5381

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

483

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 26.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号