在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组件的模板中,你可以绑定按钮的点击事件来触发平滑滚动。例如:

<template>
  <div>
    <button @click="smoothScroll">平滑滚动到顶部</button>
  </div>
</template>

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

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

  • 27
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值