0

0

CSS如何制作一个带数字跳动的加载百分比_利用counter配合content动画

P粉602998670

P粉602998670

发布时间:2026-03-08 13:21:11

|

193人浏览过

|

来源于php中文网

原创

css计数器需counter-reset与counter-increment成对使用,仅设其一无效;动画中须用steps()配合counter-increment实现离散跳变,且不支持小数、格式化及暂停恢复。

css如何制作一个带数字跳动的加载百分比_利用counter配合content动画

counter-reset 和 counter-increment 必须成对出现才能驱动数字变化

只设 counter-reset 不触发计数,只写 counter-increment 但没初始化,content 里显示为空或 0。浏览器不会自动创建计数器,必须先 counter-reset: percent 0,再在伪元素里用 counter-increment: percent 触发递增。

常见错误是把 counter-increment 放在父容器上却期望子元素的 ::after 显示变化——它只对当前元素生效,且每次渲染帧都需重新触发(靠动画重绘)。

  • 计数器名区分大小写,percentPercent 是两个计数器
  • 初始值建议显式写 counter-reset: percent 0,不依赖默认值,避免 Safari 或旧版 Chrome 行为不一致
  • 若需从 0% 跳到 100%,中间跳过 50%,得靠动画关键帧逐帧调用 counter-increment,不能靠 CSS 自动插值

content 动画必须配合 animation-timing-function + steps() 才能“跳”起来

CSS 计数器本身不支持小数或百分比格式化,content: counter(percent) "%" 只能输出整数。想实现「0→1→2→…→100」的离散跳变,不能用 easelinear,否则数字会模糊、重叠甚至闪退——因为浏览器在中间帧尝试渲染未定义的计数值(比如 counter(12.7) 无效,回退为空)。

正确做法是用 steps(100, end) 把 1s 动画切成 100 步,每步触发一次 counter-increment,确保每帧只进 1。

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

Q.AI视频生成工具
Q.AI视频生成工具

支持一分钟生成专业级短视频,多种生成方式,AI视频脚本,在线云编辑,画面自由替换,热门配音媲美真人音色,更多强大功能尽在QAI

下载
  • steps(100, end) 中的 end 表示在每步结束时才更新,避免首帧就显示 1%
  • 动画时长和 steps 数量要匹配:1s 动画配 steps(100) ≈ 每 10ms 一跳;若改成 2s,steps 也得翻倍,否则跳变变慢
  • Firefox 对 counter-increment@keyframes 里的支持较晚(v100+),低于此版本会静止在初始值

百分比符号 "%" 不能直接塞进 counter(),得拼接在 content 里

counter(percent) 只返回数字,强行写 counter(percent "%") 语法错误,浏览器直接忽略整个 content 声明。必须分开拼:content: counter(percent) "%"

如果需要补零(如 001%)、千分位(1,000%)或小数(99.5%),CSS 原生 counter 无能为力——它不支持格式化函数。这时候就得换思路:用 JS 控制 data- 属性,或改用 attr(data-pct) 配合 JS 更新。

  • 想显示「加载中… 67%」,文字部分用真实文本,百分比用伪元素覆盖,避免布局抖动
  • 移动端要注意 content 伪元素触发重排成本低,但频繁触发仍可能卡顿,别在滚动区域里滥用
  • 若需兼容 IE,彻底放弃 counter 方案,改用 JS + innerText 更新

animation-play-state: paused / running 控制跳动启停很脆弱

想暂停加载动画时调 element.style.animationPlayState = "paused",看起来停了,但计数器状态其实已“卡死”:后续恢复播放不会从暂停处继续,而是重播整个动画——因为 counter-increment 没有记忆,只响应当前帧的声明。

这意味着无法靠纯 CSS 实现「暂停/恢复」逻辑。真要控制进度,得用 JS 记录当前值,再通过修改 counter-reset 的初始值 + 重置动画来模拟。

  • 不要依赖 animationiteration 事件监听跳动完成,它在 steps() 下行为不可靠
  • getComputedStyle(el).content 读不到实时 counter 值,只能读原始字符串如 "counter(percent) "%"
  • 最稳的暂停方式:用 JS 清除 class,停止动画,同时用 dataset.pct = currentVal 保存进度
实际跳动效果是否流畅,取决于 steps 数量与动画时长的咬合精度,以及浏览器对 counter-increment 在关键帧中重绘的实现一致性——这点连 Chrome DevTools 的 Rendering 面板都未必能准确反映。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1046

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

828

2023.11.06

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

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

738

2023.08.03

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

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

219

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1188

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1163

2024.04.29

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

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

23

2026.03.06

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 40.5万人学习

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

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