温馨提示×

怎样在iframe中实现平滑滚动

小樊
122
2024-07-10 20:48:36
栏目: 编程语言

要在iframe中实现平滑滚动,可以使用JavaScript来实现。首先,在iframe的内容页面中添加以下JavaScript代码来监听页面中的滚动事件:

window.addEventListener('scroll', function() {
  window.parent.postMessage('scrolling', '*');
});

然后,在包含iframe的父页面中添加以下JavaScript代码来捕获iframe发送的滚动消息,并在父页面中实现平滑滚动效果:

window.addEventListener('message', function(event) {
  if (event.data === 'scrolling') {
    var currentPosition = window.pageYOffset;
    var targetPosition = document.getElementById('iframe').contentWindow.pageYOffset;
    var distance = targetPosition - currentPosition;

    var scrollInterval = setInterval(function() {
      var step = distance / 10;
      window.scrollTo(0, currentPosition + step);

      if (Math.abs(distance) < Math.abs(step)) {
        clearInterval(scrollInterval);
        window.scrollTo(0, targetPosition);
      }
    }, 20);
  }
});

请确保替换代码中的"iframe"为实际的iframe元素ID。这样就可以实现在iframe中的平滑滚动效果。

0