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

 更新时间:2023年12月03日 10:34:43   作者:种花的人_  
这是一个实现平滑滚动的函数,可以让页面在滚动到指定位置时产生缓动效果,本文给大家介绍了如何在在Vue页面中实现平滑滚动功能,<BR>,文中详细的代码讲解供大家参考,具有一定的参考价值,需要的朋友可以参考下

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

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

函数的参数包括:

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

函数的实现过程如下:

  • 获取当前滚动位置(start)和需要滚动的距离(change);
  • 设置每次滚动的增量(increment),默认为20;
  • 定义动画开始时间(currentTime),默认为0;
  • 根据Math.easeInOutQuad函数计算新的滚动位置值,并将其应用于文档的scrollTop属性;
  • 判断当前时间是否小于持续时间,如果是则使用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()
}

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

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

  • 在你的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方法,从而触发平滑滚动。

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

以上就是Vue页面中实现平滑滚动的效果的详细内容,更多关于Vue页面平滑滚动的资料请关注脚本之家其它相关文章!

相关文章

  • vue图片转base64格式的方法示例

    vue图片转base64格式的方法示例

    对于前后端分离的项目,为了统一响应参数,需要将图片转换成base64的格式,下面这篇文章主要给大家介绍了关于vue图片转base64格式的相关资料,需要的朋友可以参考下
    2022-12-12
  • vue优化之优雅的抛出错误(Error)问题

    vue优化之优雅的抛出错误(Error)问题

    这篇文章主要介绍了vue优化之优雅的抛出错误(Error)问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • ResizeObserver loop limit exceeded报错原因及解决方案

    ResizeObserver loop limit exceeded报错原因及解决方案

    这篇文章主要给大家介绍了关于ResizeObserver loop limit exceeded报错原因及解决的相关资料,公司项目监听系统中发现一个高频错误ResizeObserver loop limit exceeded,而浏览器的console中却没有提示,需要的朋友可以参考下
    2023-09-09
  • 如何在vue中使用unocss以及基本使用方法

    如何在vue中使用unocss以及基本使用方法

    这篇文章主要给大家介绍了关于如何在vue中使用unocss以及基本使用方法的相关资料,unocss是一个即时的原子CSS引擎,它可以让你用简短的类名来控制元素的样式,而不需要写复杂的CSS代码,需要的朋友可以参考下
    2023-07-07
  • vue中的任务队列和异步更新策略(任务队列,微任务,宏任务)

    vue中的任务队列和异步更新策略(任务队列,微任务,宏任务)

    这篇文章主要介绍了vue中的任务队列和异步更新策略(任务队列,微任务,宏任务),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue中ref实现子向父传值的示例

    vue中ref实现子向父传值的示例

    本文主要介绍了vue中ref实现子向父传值的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • vue引入ueditor及node后台配置详解

    vue引入ueditor及node后台配置详解

    这篇文章主要介绍了vue引入ueditor及node后台配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • nuxt使用vuex存储及获取用户信息踩坑的解决

    nuxt使用vuex存储及获取用户信息踩坑的解决

    这篇文章主要介绍了nuxt使用vuex存储及获取用户信息踩坑的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue 中对图片地址进行拼接的方法

    Vue 中对图片地址进行拼接的方法

    今天小编就为大家分享一篇Vue 中对图片地址进行拼接的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue 幸运大转盘实现思路详解

    Vue 幸运大转盘实现思路详解

    这篇文章主要介绍了Vue 幸运大转盘实现思路详解,需要的朋友可以参考下
    2019-05-05

最新评论