如何解决 CSS 动画中箭头移动轨迹出现突变效果?

如何解决 CSS 动画中箭头移动轨迹出现突变效果?

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 动画中箭头移动轨迹出现突变效果?的详细内容,更多请关注其它相关文章!