css动画怎么实现往返运动_css动画往返效果实现思路
发布时间 - 2026-01-25 00:00:00 点击率:次用 animation-direction: alternate 可实现去→回→去→回的往返动画,需配合 animation-iteration-count: infinite;alternate 首次正向,alternate-reverse 首次反向;应使用 transform 避免重排,必要时加 will-change: transform。
用 animation-direction: alternate 实现基础往返
默认的 CSS 动画只单向播放一次或循环,要让它“去→回→去→回”反复切换方向,核心是 animation-direction 属性。设为 alternate 后,每次迭代都会翻转动画方向:第 1 次正向执行 @keyframes,第 2 次反向执行(从 100% 倒播到 0%),第 3 次再正向……这样视觉上就是往返运动。
注意它必须配合 animation-iteration-count: infinite 才能持续往返;如果只写 alternate 但没设循环次数,动画播完一次就停了,根本看不到“返”。
div {
animation-name: slide;
animation-duration: 2s;
animation-iteration-count: infinite;
animation-direction: alternate;
}
@keyframes slide {
from { transform: translateX(0); }
to { transform: translateX(100px); }
}
alternate-reverse 和 alternate 的区别在哪
两者都做往返,但起始方向不同:alternate 第 1 轮正向(0% → 100%),alternate-reverse 第 1 轮反向(100% → 0%)。如果你的动画初始状态

-
alternate:适合“从起点出发→到终点→返回起点→再出发…”这种自然节奏 -
alternate-reverse:适合“先在终点待着→突然往回跑→到起点→再冲出去…”这类反直觉动效 - 绝大多数往返需求用
alternate就够了,别为了“听起来更全”硬套alternate-reverse
往返动画卡顿?检查 transform 和 will-change
往返运动频繁触发重排(reflow)时容易掉帧,尤其涉及 left/top 这类会触发布局计算的属性。必须用 transform: translateX() 等合成层友好的属性。
另外,如果动画元素本身结构复杂或父容器有遮罩/滤镜,建议加 will-change: transform 提前提示浏览器升层——但别滥用,每个元素都加反而拖慢初始化。
- ✅ 正确:用
transform: translateX()、scale()、rotate() - ❌ 避免:用
left、margin-left、width触发 layout - ⚠️ 谨慎:
will-change: transform只加在真正动画的元素上,且动画结束后最好设回auto
想控制“往返”的停顿时间?靠 @keyframes 手动分段
alternate 是匀速往返,没法在两端“多停一会儿”。如果需要“走到右边→停 0.5s→慢慢回来→在左边停 0.5s”,就得放弃 alternate,改用单向循环 + 关键帧内控时长:
@keyframes pingpong {
0%, 20% { transform: translateX(0); } /* 左边停住 */
50% { transform: translateX(100px); } /* 走到右边 */
80%, 100% { transform: translateX(0); } /* 回到左边并停住 */
}
div {
animation: pingpong 4s infinite;
}
这里 0%–20% 和 80%–100% 都是静止区间,实际运动只占中间 30% 时间。百分比数值可按需调整,但要注意总和必须是 100%,否则节奏错乱。
这种写法灵活,但维护成本高;alternate 简洁但不够精细——选哪个,取决于你是否真需要那几毫秒的停顿精度。
# css
# 浏览器
# 区别
# css动画
# count
# auto
# 循环
# margin
# transform
# animation
# 首次
# 走到
# 这类
# 停住
# 滤镜
# 都是
# 设为
# 要让
# 就得
# 停了
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
如何注册花生壳免费域名并搭建个人网站?
奇安信“盘古石”团队突破 iOS 26.1 提权
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
Swift中swift中的switch 语句
网站制作软件有哪些,制图软件有哪些?
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
利用vue写todolist单页应用
UC浏览器如何设置启动页 UC浏览器启动页设置方法
BootStrap整体框架之基础布局组件
谷歌Google入口永久地址_Google搜索引擎官网首页永久入口
如何解决hover在ie6中的兼容性问题
如何自定义建站之星网站的导航菜单样式?
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
新三国志曹操传主线渭水交兵攻略
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
太平洋网站制作公司,网络用语太平洋是什么意思?
java中使用zxing批量生成二维码立牌
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】
Laravel集合Collection怎么用_Laravel集合常用函数详解
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
公司门户网站制作流程,华为官网怎么做?
Laravel安装步骤详细教程_Laravel环境搭建指南
Windows Hello人脸识别突然无法使用
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
EditPlus 正则表达式 实战(3)
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
香港服务器租用每月最低只需15元?
Android GridView 滑动条设置一直显示状态(推荐)
Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)
Laravel如何使用Sanctum进行API认证?(SPA实战)
Laravel如何为API编写文档_Laravel API文档生成与维护方法
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
深圳网站制作平台,深圳市做网站好的公司有哪些?
如何快速搭建支持数据库操作的智能建站平台?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
EditPlus中的正则表达式 实战(1)
如何在IIS中配置站点IP、端口及主机头?
java获取注册ip实例
Laravel如何实现用户密码重置功能?(完整流程代码)
桂林网站制作公司有哪些,桂林马拉松怎么报名?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
深入理解Android中的xmlns:tools属性
Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑

