CSS动画暂停后如何继续?修改animation-play-state属性
时间:2026-03-14 08:03:31 138浏览 收藏
CSS动画的暂停与继续只需通过`animation-play-state`属性轻松实现——设为`paused`即可即时暂停,设为`running`便能无缝续播,全程保持动画进度、节奏和关键帧位置不变;既支持JavaScript直接操作内联样式的便捷写法(`element.style.animationPlayState`),也推荐通过预定义CSS类名(如`.paused`/`.running`)切换来提升可维护性;它完美兼容现代浏览器,还能精准控制多个动画的独立状态,是实现交互式动画体验不可或缺的核心技巧。

通过修改 animation-play-state 属性,可以控制 CSS 动画的暂停与继续:设为 paused 暂停,设为 running 继续。
直接修改元素的内联样式
这是最常用、最直接的方式。JavaScript 中通过 element.style 设置:
- 暂停动画:
element.style.animationPlayState = 'paused'; - 继续动画:
element.style.animationPlayState = 'running';
注意:该写法使用驼峰命名(animationPlayState),对应 CSS 中的连字符写法 animation-play-state。它只影响内联样式,优先级高,会覆盖 CSS 文件中的定义。
切换 class 类名来控制状态
更推荐的维护方式是预先在 CSS 中定义好状态类,再用 JS 切换:
CSS 部分:
.animated { animation: slide 2s infinite; }
.paused { animation-play-state: paused; }
.running { animation-play-state: running; }
JS 部分:
- 暂停:
element.classList.add('paused'); - 继续:
element.classList.remove('paused');(或添加'running')
这种方式利于样式集中管理,也方便配合 transition 或其他状态做组合控制。
注意动画时间点的连续性
暂停/继续不会重置动画进度。例如动画执行到 1.2s 时暂停,再继续就会从 1.2s 处接着播放,保持原有节奏和关键帧位置。
但要注意:如果动画已结束(比如非无限循环的一次性动画),再设为 running 不会重新开始 —— 它已处于“完成态”。如需重播,得先重置动画,例如通过移除再添加 class、或用 void element.offsetHeight 强制重排后重新触发。
兼容性与多动画处理
animation-play-state 在现代浏览器中支持良好(Chrome 43+、Firefox 16+、Safari 9+、Edge 全支持)。若元素有多个动画(用逗号分隔),该属性也支持用逗号传多个值,例如:
element.style.animationPlayState = 'running, paused'; // 分别控制两个动画
未指定的则沿用默认值 running。建议显式写全,避免歧义。
今天关于《CSS动画暂停后如何继续?修改animation-play-state属性》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
213 收藏
-
419 收藏
-
282 收藏
-
210 收藏
-
262 收藏
-
238 收藏
-
411 收藏
-
305 收藏
-
174 收藏
-
162 收藏
-
478 收藏
-
338 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习