javascript动画如何制作_有哪些实现动画的方法【教程】
发布时间 - 2026-01-31 00:00:00 点击率:次优先用 requestAnimationFrame 实现平滑动画,它匹配屏幕刷新率、后台暂停省资源;简单视觉变化用 CSS transition 或 @keyframes;复杂动态控制用 Web Animations API;避免触发重排,只用 transform、opacity、filter 等高效属性。
用 requestAnimationFrame 做平滑动画,别用 setTimeout 或 setInterval
浏览器对 requestAnimationFrame 有专门优化,能自动匹配屏幕刷新率(通常是 60fps),而 setTimeout 的执行时机不可控,容易掉帧或卡顿。尤其在页面后台运行时,setTimeout 仍会执行,但 requestAnimationFrame 会暂停,更省资源。
常见错误是手动写死 16ms 间隔:setTimeout(fn, 16) —— 这不等于 60fps,因为 JS 执行、重排、重绘都耗时,实际帧率可能只有 40fps 甚至更低。
正确做法是递归调用:
function animate() {
// 更新状态,比如 element.style.transform = `translateX(${x}px)`
// 触发重排/重绘
requestAnimationFrame(animate)
}
requestAnimationFrame(animate)
CSS 动画和过渡更适合简单视觉变化
如果只是位移、缩放、透明度、颜色这类属性变化,优先用 transition 或 @keyframes。它们由浏览器合成线程处理,不阻塞主线程,性能远超 JS 操作样式。
注意几个易错点:
-
transition只在属性值“变化时触发”,比如从opacity: 0到opacity: 1;但如果用 JS 快速连续设多次style.opacity,可能只触发最后一次过渡 -
transform和opacity是仅有的两个能触发硬件加速的 CSS 属性(在多数浏览器中),其他如left、top会引发频繁重排,卡顿明显 - 用
will-change: transform提前提示浏览器要动画,但别滥用——它会提前分配图层内存,过度使用反而降低性能
Web Animations API(element.animate())适合动态控制
当需要运行时生成动画、暂停/回放/调节速度,或者组合多个属性动画时,element.animate() 比纯 CSS 更灵活,也比手写 requestAnimationFrame 简洁。
它返回一个 Animation 对象,可直接调用 .pause()、.play()、.reverse()、.currentTime 等方法。
示例:让元素左右晃动三次
const anim = element.animate(
[
{ transform: 'translateX(0)' },
{ transform: 'translateX(-10px)' },
{ transform: 'translateX(0)' },
{ transform: 'translateX(10px)' },
{ transform: 'translateX(0)' }
],
{
duration: 600,
iterations: 3
}
)
兼容性注意:IE 完全不支持,Safari 16.4+ 才支持 iterationStart 等高级参数,生产环境建议加降级(比如 fallback 到 requestAnimationFrame)。
动画卡顿?先查是否触发了 Layout(重排)
真正拖慢动画的往往不是“动”,而是“动的时候浏览器被迫重新计算布局”。比如读取 offsetTop、getBoundingClientRect() 后立刻改样式,就会强制同步触发布局计算。
排查方式:
- Chrome DevTools → Rendering → 勾选 “Layout Shift Regions” 和 “FPS Meter”
- 在 Performance 面板录制动画过程,看 Flame Chart 中是否有大量绿色(Layout)块
- 避免在动画帧内读写交替:把所有读操作集中到开头,所有写操作集中到结尾
最稳妥的动画属性只有三个:transform、opacity、filter(部分浏览器支持)。其他都尽量避免。
# css
# javascript
# java
# js
# 浏览器
# safari
# 硬件加速
# 重绘
# chrome
# chrome devtools
# Filter
# 递归
# 线程
# 主线程
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何确保FTP站点访问权限与数据传输安全?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
如何在阿里云部署织梦网站?
Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】
linux写shell需要注意的问题(必看)
大型企业网站制作流程,做网站需要注册公司吗?
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
如何确保西部建站助手FTP传输的安全性?
php做exe能调用系统命令吗_执行cmd指令实现方式【详解】
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
JavaScript中的标签模板是什么_它如何扩展字符串功能
如何用腾讯建站主机快速创建免费网站?
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
香港服务器租用费用高吗?如何避免常见误区?
如何批量查询域名的建站时间记录?
Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】
如何在万网自助建站平台快速创建网站?
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
手机网站制作与建设方案,手机网站如何建设?
Laravel如何创建自定义Facades?(详细步骤)
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
如何在IIS中新建站点并配置端口与物理路径?
Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
Java遍历集合的三种方式
如何在万网开始建站?分步指南解析
如何快速查询域名建站关键信息?
公司网站制作价格怎么算,公司办个官网需要多少钱?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
如何获取上海专业网站定制建站电话?
网站建设要注意的标准 促进网站用户好感度!
香港服务器WordPress建站指南:SEO优化与高效部署策略
如何在阿里云服务器自主搭建网站?
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
如何快速登录WAP自助建站平台?
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
如何在阿里云通过域名搭建网站?
如何在阿里云域名上完成建站全流程?
Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
nodejs redis 发布订阅机制封装实现方法及实例代码
Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】
网站优化排名时,需要考虑哪些问题呢?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?


