
css 动画中的突变效果:优化箭头移动轨迹
在 CSS 动画中,需要实现两个小箭头从左向右依次移动的效果。箭头 a 的移动路径非常简单,可以使用 @keyframes 实现。然而,箭头 b 的移动轨迹较为复杂,需要先从 30% 位置移动到 100%,再从 0 开始移动到 30%。
最开始的尝试是按照箭头 a 的思路写一个 @keyframes 动画,但在 69% 到 70% 之间,箭头会瞬间从 100px 移回 0px。
解决方案
为了直接定位到 0,而不增加动画效果,可以使用负数的 animation-delay 属性来提前开始效果。比如说,设置箭头 b 的 animation-delay 为 -3s,则它会比箭头 a 早 3 秒开始动画。这样,箭头 b 就能从 30% 开始移动到 100%,再从 0 开始移动到 30%,而不会出现突变效果。
立即学习“前端免费学习笔记(深入)”;
.block {
animation: 10s linear;
}
.start3 {
animation-delay: -3s
}复杂路径的应对方式
如果需要实现从 30% 到 100% 再回 0% 再继续到 30% 停止这样的复杂路径,则需要编写一个单独的动画,不能使用同一个 CSS 动画。在回归时,可以设置透明度或将箭头移动到容器外部,然后再回到初始位置。
<!-- 设置箭头 b 的移动路径 -->
<div class="arrow-b">
<!-- 从 30% 到 100% -->
<div class="move1">
<!-- ... -->
</div>
<!-- 从 0% 到 30% -->
<div class="move2">
<!-- ... -->
</div>
</div>以上就是如何解决 CSS 动画中箭头移动轨迹出现突变效果?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号