最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
HTML里使用CSS的animation-timing-function steps实现逐帧动画
时间:2026-06-23 09:54:13 编辑:袖梨 来源:一聚教程网
steps()需配合animation或transition生效,单独使用无效;background-position+steps是雪碧图逐帧动画最稳定方案,因硬件加速成熟、不触发重排;8帧需steps(7),范围0→-700px;IE10+等主流浏览器均支持。
steps() 不是动画本身,它只是告诉动画“怎么动”——必须配合 animation 或 transition 才能生效。单独写 steps(4),页面不会有任何变化。
为什么 background-position + steps 是最稳的逐帧方案
雪碧图(sprite sheet)是 steps() 最典型、兼容性最好、行为最可预测的使用场景。浏览器对 background-position 的硬件加速支持成熟,且该属性变更不触发重排,性能开销低。
- 雪碧图必须横向等宽排列,总宽度 = 单帧宽度 × 帧数;例如 8 帧 × 100px = 800px,则
background-position动画范围是0→-700px(不是-800px) -
steps()的第一参数不是帧数,而是“跳跃次数”:8 帧需steps(7),因为从第 0 帧跳到第 7 帧共 7 次 - 容器必须设固定宽高,
background-size设为原始图宽(如800px auto),否则缩放会导致帧错位 - IE10+、Chrome 23+、Firefox 16+、Edge 12+ 均原生支持,无需前缀
steps(n, start) 和 steps(n, end) 的实际差异
默认是 steps(n, end),但很多人卡在“为什么第一帧要等 1/n 时间才出现”。关键看起始状态是否需要立即呈现:
-
steps(4, end)(默认):0% 时显示第 0 帧,25% 时跳到第 1 帧,50% 跳第 2 帧,75% 跳第 3 帧,最后 25% 停在第 4 帧(即终点) -
steps(4, start):0% 时立刻跳到第 1 帧,25% 跳第 2 帧,50% 跳第 3 帧,75% 跳第 4 帧,100% 停在第 4 帧 - 打字机效果常用
start,让第一个字符立刻出现;雪碧图一般用end更符合直觉
常见报错和静默失败原因
写完 steps() 却没动画?大概率不是语法错,而是绑定或计算问题:
立即学习“前端免费学习笔记(深入)”;
- 忘了在
animation或transition中声明对应属性:比如只写了animation: play 1s steps(7);,但@keyframes play里改的是opacity,而没动background-position -
steps()第一个参数不是整数(如steps(3.5)):浏览器直接忽略该 timing function,退回到ease - 动画时长太短(如
0.1s)或帧数太多(如steps(30)):人眼无法分辨跳变,看起来像平滑移动甚至“不动” - 雪碧图背景图路径错误、尺寸未设、或被父元素
overflow: hidden截断:检查 computed styles 中background-position是否真在变化
真正容易被忽略的点是:steps 的“步”对应的是动画属性值的离散变化点,不是视觉帧数——它不管图里有没有画对,只管你 keyframes 里 from/to 写的两个值之间被切了几刀。数值算错一帧,整段动画就偏移。
相关文章
- centos 时间戳在脚本里的应用 06-27
- centos 时间戳怎样同步 06-27
- centos 时间戳与系统时间关系 06-27
- centos 时间戳显示不正确如何解决 06-27
- centos 时间戳有哪些作用 06-27
- centos 时间戳转换办法 06-27