在Vue页面中实现平滑滚动功能

这是一个实现平滑滚动的函数,可以让页面在滚动到指定位置时产生缓动效果

该函数依赖于Math.easeInOutQuad函数和requestAnimFrame函数,其中Math.easeInOutQuad函数用于计算当前滚动位置的值(根据时间、起始值、变化量和持续时间),requestAnimFrame函数用于实现动画效果。

函数的参数包括:

  • to: 目标滚动位置;
  • duration: 滚动持续时间,默认为500毫秒;
  • callback: 滚动结束后的回调函数。

函数的实现过程如下:

  1. 获取当前滚动位置(start)和需要滚动的距离(change);
  2. 设置每次滚动的增量(increment),默认为20;
  3. 定义动画开始时间(currentTime),默认为0;
  4. 根据Math.easeInOutQuad函数计算新的滚动位置值,并将其应用于文档的scrollTop属性;
  5. 判断当前时间是否小于持续时间,如果是则使用requestAnimFrame函数继续执行动画,否则执行回调函数。
Math.easeInOutQuad = function(t, b, c, d) {
  t /= d / 2
  if (t < 1) {
    return c / 2 * t * t + b
  }
  t--
  return -c / 2 * (t * (t - 2) - 1) + b
}

var requestAnimFrame = (function() {
  return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60) }
})()

/**
 * @param {number} amount
 */
function move(amount) {
  document.documentElement.scrollTop = amount
  document.body.parentNode.scrollTop = amount
  document.body.scrollTop = amount
}

function position() {
  return document.documentElement.scrollTop || document.body.parentNode.scrollTop || document.body.scrollTop
}

/**
 * @param {number} to
 * @param {number} duration
 * @param {Function} callback
 */
export function scrollTo(to, duration, callback) {
  const start = position()
  const change = to - start
  const increment = 20
  let currentTime = 0
  duration = (typeof (duration) === 'undefined') ? 500 : duration
  var animateScroll = function() {
    // increment the time
    currentTime += increment
    // find the value with the quadratic in-out easing function
    var val = Math.easeInOutQuad(currentTime, start, change, duration)
    // move the document.body
    move(val)
    // do the animation unless its over
    if (currentTime < duration) {
      requestAnimFrame(animateScroll)
    } else {
      if (callback && typeof (callback) === 'function') {
        // the animation is done so lets callback
        callback()
      }
    }
  }
  animateScroll()
}

要使用这个平滑滚动的功能,你需要按照以下步骤进行操作:

  1. 将上述代码复制到你的项目中的一个文件中(比如scroll.js),并确保该文件被引入到你的Vue组件中。

  2. 在你的Vue组件中,可以通过以下方式调用scrollTo函数:

import { scrollTo } from './scroll.js';

export default {
  methods: {
    smoothScroll() {
      scrollTo(0, 1000, () => {
        console.log('滚动结束!');
      });
    }
  },
};

         在上面的例子中,我们将scrollTo函数封装在Vue组件的methods选项中的smoothScroll方法中。当你希望触发平滑滚动时,可以在模板或其他方法中调用这个方法。

在Vue组件的模板中,你可以绑定按钮的点击事件来触发平滑滚动。例如:


在上面的例子中,当按钮被点击时,会调用smoothScroll方法,从而触发平滑滚动。

确保根据你的实际需求修改代码中的目标滚动位置、持续时间和回调函数等参数。

你可能感兴趣的:(前端,vue)