用 CSS animation 和 transform: translateX() 可纯 CSS 实现图片轮播:HTML 扁平结构+flex 横排,父容器 overflow: hidden;@keyframes 控制 translateX 分段位移(如 4 图设 0%/-100%/-200%/-300%/0%),配合 steps() 或精确时间点实现停顿滑动效果。

用 CSS animation 和 transform: translateX() 实现图片轮播,核心是让一组图片在水平方向上依次位移,形成循环滑动效果。不需要 JS 也能完成,但需注意结构布局和关键帧控制逻辑。
把所有图片放在一个容器内,用 display: flex 横向排列,确保总宽度足够容纳全部图片(避免换行):
<div class="carousel"> @@##@@ @@##@@ @@##@@ @@##@@ </div>
注意:所有图片宽高需一致,或用 flex-shrink: 0 防止压缩;父容器设 overflow: hidden 裁剪超出部分。
动画本质是让整个图片组从左往右(或右往左)匀速移动,每张图占据 100% 容器宽度,位移单位为 100%。假设 4 张图,完整一轮需移动 -300%(即前三张图的宽度),最后回到起点形成循环:
立即学习“前端免费学习笔记(深入)”;
@keyframes 定义从 translateX(0) 到 translateX(-300%) 的线性运动infinite 循环translateX(0),否则会跳变;可用 steps(4) 或分段 keyframes 控制停顿示例动画(4 图无缝循环):
@keyframes slide {
0% { transform: translateX(0); }
25% { transform: translateX(-100%); }
50% { transform: translateX(-200%); }
75% { transform: translateX(-300%); }
100% { transform: translateX(0); }
}
.carousel {
display: flex;
overflow: hidden;
animation: slide 8s ease-in-out infinite;
}如果希望每张图静止展示 2 秒、滑动 0.5 秒,就不用 ease-in-out,改用 steps(4) 或手动拆分关键帧时间点:
10s(4 图 × 2s 展示 + 4 次过渡 × 0.5s = 10s)0%, 20%, 40%, 60% 分别对应四张图起始位置,用 transform: translateX(-N%)
这样就能模拟“停→滑→停→滑”的真实轮播节奏。
移动端要注意开启硬件加速,加 transform: translateZ(0) 或 will-change: transform 提升流畅度;若图片多,可复制首尾图实现视觉无缝(即 1-2-3-4-1),但 CSS 动画中更推荐用 keyframes 精确控制位移值,避免 DOM 扩展。




以上就是css图片轮播动画怎么写_利用animation和位移切换的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号