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>
登录后复制
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容