标签导航:

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中的动画参数,可以有效地消除动画重置时的细微位移。需要注意的是,此解决方案主要适用于单行滚动效果,多行滚动可能需要进一步的调整。