首页 > web前端 > css教程 > 正文

CSS animation重置时出现移动痕迹,如何解决?

聖光之護
发布: 2025-02-23 16:04:01
原创
236人浏览过

css动画重置时的细微位移问题及解决方案

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

CSS animation重置时出现移动痕迹,如何解决?

本文提供一种有效的解决方案,通过调整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代码调整:

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重置时出现移动痕迹,如何解决?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号