css动画怎么实现往返运动_css动画往返效果实现思路
技术百科
P粉602998670
发布时间:2026-01-25
浏览: 次 用 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
# 走到
# 设为
# auto
# 循环
# 区别
# count
# transform
# animation
# 停住
# margin
# css动画
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win11怎么查看已连接wifi密码 Win11查
- Windows10如何删除Windows.old_
- PHP接收参数值为空怎么办_判断和处理空参数方法说
- 微信JSAPI支付回调PHP怎么接收_处理JSAP
- Go语言中CookieJar的持久化机制解析:内存
- MAC的“接续互通”功能无法使用怎么办_MAC检查
- 如何使用Golang构建简易投票统计功能_Gola
- C++友元类使用场景_C++类间协作设计方式讲解
- Go语言中正确反序列化多个同级XML元素为结构体切
- 如何使用Golang实现容器健康检查_监控和自动重
- Python函数缓存机制_lru_cache解析【
- Windows执行文件被SmartScreen拦截
- 如何使用正则表达式提取以编号开头、后跟多个注解的完
- Windows7如何安装系统镜像_Windows7
- Win10如何更改网络连接_Windows10以太
- ACF 教程:正确更新嵌套在多层 Group 字段
- VSC怎么在PHP中调试MySQL_数据库交互排查
- Win10如何备份驱动程序_Win10驱动备份步骤
- 如何解决Windows字体显示模糊的问题?(Cle
- php怎么下载安装后设置错误日志_phpini l
- Windows10系统怎么查看运行时间_Win10
- Windows笔记本无法进入睡眠模式怎么办?(电源
- Win11搜索栏无法输入_解决Win11开始菜单搜
- Python函数参数高级用法_默认值与可变参数解析
- Mac电脑进水了怎么办_MacBook进水后紧急处
- 如何优化Golang内存分配与GC调度_Golan
- win11如何清理传递优化文件 Win11为C盘瘦
- Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱
- Linux如何申请SSL免费证书_Linux下Ce
- Win11如何连接Xbox手柄 Win11蓝牙连接
- Win11怎么更改电脑名称_Windows 11修
- php修改数据怎么批量改状态_批量更新status
- Win11系统更新后黑屏怎么办 Win11更新黑屏
- Win11相机打不开提示错误怎么修_相机权限开启与
- Windows如何拦截2345弹窗广告_Windo
- PHP cURL GET请求:正确设置认证与自定义
- Win10如何卸载WindowsDefender_
- Win11 C盘满了怎么清理 Win11磁盘清理和
- Windows蓝屏BAD_POOL_HEADER故
- 如何用::实现单例模式_php静态方法与作用域操作
- c++ reinterpret_cast怎么用 c
- Windows10系统服务优化指南_Win10禁用
- c# 在高并发场景下,委托和接口调用的性能对比
- c++的static关键字有什么用 静态变量和静态
- Win11怎么关闭自动调节屏幕亮度_Windows
- Python变量绑定机制_引用模型解析【教程】
- 如何使用Golang实现微服务状态监控_Golan
- 如何使用Golang实现跨域请求支持_Golang
- Win11怎么设置系统还原_Windows11系统
- Python音视频处理高级项目教程_FFmpegP


QQ客服