css动画重置时的细微位移问题及解决方案
在使用CSS动画实现滚动效果并重置到初始状态时,常常会遇到一个恼人的问题:动画回到起始帧时,元素会出现细微的位移。这与使用requestAnimationFrame控制的JavaScript动画版本有所不同。CSS动画在回到第一帧时,可能会出现轻微的下移或其他不自然的移动。

本文提供一种有效的解决方案,通过调整CSS和JavaScript代码来消除这种细微的位移。
CSS代码调整:
立即学习“前端免费学习笔记(深入)”;
为了解决这个问题,可以在动画的第一帧添加一个微小的反向位移,以此抵消重置时出现的位移。以下代码片段展示了这种方法:
.m-tb-scroll tbody.ani { animation-name: scroll-fix;}@keyframes scroll-fix { 0% { transform: translateY(var(--scrolltopdebounce)); } 1% { transform: translateY(-1px); /* 添加一个微小的反向位移 */ }}
关键在于1%帧添加的translateY(-1px),它在动画起始阶段引入了一个微小的反向位移,有效地抵消了重置时产生的位移。
JavaScript代码调整:
网易人工智能
网易数帆多媒体智能生产力平台
206 查看详情
JavaScript代码需要配合CSS动画的调整,精确控制动画参数。以下代码片段展示了如何调整--scrolltopdebounce变量:
if (scroll > 10) { target.classList.remove('scroll'); target.classList.add('ani'); let scrollDuration = scroll / 60; document.body.style.setProperty('--scrollDuration', `${scrollDuration}s`); document.body.style.setProperty('--scrollY', `-${scroll}px`); document.body.style.setProperty('--scrollTopDebounce', `-${scroll - 1}px`); /* 调整此行 */ this.setAnimationPause();}
这里将--scrollTopDebounce的值设置为-${scroll - 1}px,使其与--scrollY的值略微不同,从而实现微调。
在线示例:
您可以访问以下链接查看完整的代码示例:代码预览
总结:
CSS动画的重置问题源于其对第一帧的控制不足。通过在第一帧添加一个微小的反向位移,并精确控制JavaScript中的动画参数,可以有效地消除动画重置时的细微位移。需要注意的是,此解决方案主要适用于单行滚动效果,多行滚动可能需要进一步的调整。
以上就是CSS animation重置时出现移动痕迹,如何解决?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1141378.html
微信扫一扫
支付宝扫一扫