如何解决 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>
登录后复制

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容