0

0

javascript动画如何实现_requestAnimationFrame有什么优势?

夢幻星辰

夢幻星辰

发布时间:2026-01-04 22:14:02

|

981人浏览过

|

来源于php中文网

原创

requestanimationframe 是浏览器原生的重绘调度器,按屏幕刷新率执行动画回调,比 settimeout 更精准、节能、顺滑;它自动暂停非激活页面动画,避免丢帧和无效计算,且提供高精度时间戳用于帧率自适应动画。

javascript动画如何实现_requestanimationframe有什么优势?

requestAnimationFrame 是什么,为什么不用 setTimeout 做动画?

requestAnimationFrame浏览器提供的原生 API,用于在下一次重绘前执行动画回调。它不是定时器,而是“重绘调度器”——浏览器知道你打算做动画,会自动把回调塞进渲染流水线里,和屏幕刷新率(通常是 60Hz)对齐。

setTimeoutsetInterval 模拟动画时,你无法控制回调实际执行时机:可能两次回调挤在同一帧,也可能跨帧丢帧,还可能在页面非激活状态(比如切到其他 tab)下继续执行,白耗 CPU。

requestAnimationFrame 自动暂停非可见页面的回调,且保证每次只调一次、紧贴刷新节奏,天然防抖、节能、顺滑。

怎么写一个基础的 requestAnimationFrame 动画循环?

核心是“递归调用 + 状态更新 + 条件退出”,不是一次性注册。常见错误是漏掉下一次调用,或没清空上一次 ID 导致失控。

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

  • 必须在回调函数末尾再次调用 requestAnimationFrame,否则只执行一帧
  • 用返回值(一个数字 ID)配合 cancelAnimationFrame 手动终止,比如用户点击暂停、元素移出视口
  • 动画逻辑里别直接操作 DOM 样式,优先用 transformopacity,避免触发重排(layout)
let animationId = null;
const element = document.getElementById('box');
let x = 0;
<p>function animate() {
x += 2;
if (x > 400) return; // 退出条件</p><p>element.style.transform = <code>translateX(${x}px)</code>;
animationId = requestAnimationFrame(animate); // 关键:递归调度
}</p><p>animationId = requestAnimationFrame(animate);</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/745" title="What-the-Diff"><img
                                                                                src="https://img.php.cn/upload/ai_manual/001/503/042/68b6dc516822a519.png" alt="What-the-Diff"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/745" title="What-the-Diff">What-the-Diff</a>
                                                                        <p>检查请求差异,自动生成更改描述</p>
                                                                </div>
                                                                <a href="/ai/745" title="What-the-Diff" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div><p>// 暂停时调用:
// cancelAnimationFrame(animationId);
// animationId = null;

requestAnimationFrame 的时间戳参数有什么用?

回调函数默认接收一个高精度时间戳(单位毫秒,从页面加载开始),类型是 DOMHighResTimeStamp。它比 Date.now() 更准,且不受系统时间调整影响,适合做匀速、缓动、帧率自适应动画。

例如实现“每秒移动 100px”的匀速位移,不能靠帧数(因为帧率可能波动),而应基于时间差计算:

  • 记录上一帧的时间戳
  • 当前帧减去上一帧,得到真实经过的毫秒数
  • 用这个 delta 计算本次该走多远:distance = speed * (delta / 1000)
let lastTime = 0;
const speed = 100; // px/s
<p>function animate(time) {
if (!lastTime) lastTime = time;
const delta = time - lastTime;
lastTime = time;</p><p>const moveX = (speed * delta) / 1000;
element.style.transform = <code>translateX(${x + moveX}px)</code>;</p><p>requestAnimationFrame(animate);
}</p><p>requestAnimationFrame(animate);

兼容性与常见陷阱

requestAnimationFrame 在现代浏览器中已全覆盖(包括 iOS Safari 6.1+、Android Browser 4.4+),但旧安卓 WebView 或 IE9- 需要 polyfill。不过现在基本不用考虑了。

真正容易踩的坑是:在动画中频繁读取 offsetTopgetBoundingClientRect() 这类会强制同步触发重排的属性。哪怕只读一次,也可能打断浏览器的渲染优化,导致卡顿。

还有就是忘记清理。比如组件卸载、路由跳转后,如果 requestAnimationFrame 还在跑,就会持续占用资源,甚至引发内存泄漏——尤其在 React/Vue 等框架里,务必在销毁钩子中调用 cancelAnimationFrame

时间戳不是万能的。如果动画逻辑本身很重(比如大量计算或 DOM 操作),哪怕用了 requestAnimationFrame,依然会掉帧。这时候得拆逻辑、用 Web Worker,或者改用 CSS 动画。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4328

2024.08.14

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

338

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1819

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2134

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

284

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

380

2024.03.01

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.1万人学习

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

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