0

0

css动画如何实现进度条效果_css动画进度展示实现思路

P粉602998670

P粉602998670

发布时间:2026-02-02 10:10:31

|

750人浏览过

|

来源于php中文网

原创

用 transform: scaleX() 驱动进度条最可控,因不触发重排、仅影响合成层,配合 overflow: hidden 容器、transform-origin: left center 及 CSS 自定义属性 --progress,再通过 @keyframes + animation 实现高性能、可暂停、易扩展的动画效果。

css动画如何实现进度条效果_css动画进度展示实现思路

transform: scaleX() 驱动进度条动画最可控

直接操作宽度(width)会触发重排,而 transform: scaleX() 仅影响合成层,性能好、动画顺滑,且能精准控制起始/结束比例。关键在于把进度条容器设为 overflow: hidden,内部元素用 transform: scaleX(0)scaleX(1) 实现伸展效果。

  • 容器必须设固定宽高和 overflow: hidden,否则缩放会溢出
  • 动画元素需设 transform-origin: left center,确保从左向右展开
  • 若需支持 IE10+,补上 -ms-transform 前缀(现代项目通常可忽略)
  • 进度值建议用 CSS 自定义属性(--progress: 0.65)传入,便于 JS 动态更新

@keyframes + animation 控制播放节奏

不要用 transition 做“从 0 到 100%”的单次进度条——它无法控制动画时长、缓动曲线或暂停。改用 @keyframes 定义关键帧,再通过 animation 绑定,才能灵活适配加载、上传、表单验证等不同场景。

  • animation-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1) 可模拟“先快后慢再收尾”的真实加载感
  • animation-fill-mode: forwards 确保动画结束后保持最终状态(scaleX(1)
  • 需要手动暂停?用 animation-play-state: paused,比 JS 控制 class 更轻量
@keyframes progress-grow {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

.progress-bar::after { content: ''; display: block; height: 4px; background: #4a90e2; transform-origin: left center; animation: progress-grow 1.8s ease-out forwards; }

JS 动态更新进度时避免强制同步布局

如果用 JS 每次都改 style.width 或读取 offsetWidth,会频繁触发重排,尤其在循环中更新多个进度条时卡顿明显。正确做法是只写不读,用 CSS 变量 + transform 配合 requestAnimationFrame 批量更新。

  • element.style.setProperty('--progress', value) 更新变量,CSS 内用 transform: scaleX(var(--progress))
  • 不要在 for 循环里直接设 style —— 先收集所有目标元素,再统一用 requestAnimationFrame 批量更新
  • 若需监听进度完成事件,监听 animationend 比轮询更可靠

兼容性与 fallback 要点:IE 和 Safari 的坑

Safari 旧版本(≤15.4)对 transform: scaleX() 动画有渲染抖动;IE11 不支持 CSS 变量,也无法用 animation-fill-mode: forwards 保持最终状态。必须做降级处理。

Magic Eraser
Magic Eraser

AI移除图片中不想要的物体

下载

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

  • IE11 下回退到 width + transition,加 will-change: width 提升合成层
  • Safari 中避免在 scaleX() 动画期间同时修改其他 layout 属性(如 padding
  • @supports (animation: name 1s) 包裹高级动画规则,老浏览器自动跳过
@supports (animation: test 1s) {
  .progress-bar::after {
    transform: scaleX(var(--progress, 0));
  }
}

@supports not (animation: test 1s) { .progress-bar::after { width: calc(var(--progress, 0) * 100%); } }

实际用起来,最难的不是写动画,而是让进度值和业务逻辑真正对齐——比如上传中断后如何恢复动画位置、错误状态要不要回退、多步骤流程中各阶段进度如何叠加。这些得靠 JS 状态管理兜底,CSS 动画只负责“怎么动”,不动“为什么动”。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

489

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

17

2025.12.06

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是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5379

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

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.31

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 26.3万人学习

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

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