锚点定位回到顶部-JS函数封装

发布于:2024-04-29 ⋅ 阅读:(27) ⋅ 点赞:(0)

1.js scrollto 动画

原生JS基于window.scrollTo()封装垂直滚动动画工具函数,可应用与锚点定位、回到顶部等操作。
####封装原因:
在vue项目中,遇到需要实现垂直滚动效果的需求,初步想到的方法有两个:
1:使用window.scrollTo()方法,但是这个方法是没有动画效果的,需要手动封装一下。
2:使用JQuery的动画函数,缺点比较明显:需要引入JQuery。
显然,选择第一种好很多。
以下为封装window.scrollTo()的方法scroll(),文件名为scroll.js

/**
 * @param {numeber} currentY 需要移动的dom当前位置离网页顶端的距离
 * @param {number} targetY 需要移动的dom当前位置离要移到的位置的距离
 */
function scroll(currentY, targetY) {
  // 计算需要移动的距离
  const needScrollTop = targetY - currentY
  let _currentY = currentY
  setTimeout(() => {
    // 一次调用滑动帧数,每次调用会不一样
    const dist = Math.ceil(needScrollTop / 10)
    _currentY += dist
    window.scrollTo(_currentY, currentY)
    // 如果移动幅度小于十个像素,直接移动,否则递归调用,实现动画效果
    if (needScrollTop > 10 || needScrollTop < -10) {
      scroll(_currentY, targetY)
    } else {
      window.scrollTo(_currentY, targetY)
    }
  }, 1)
}
// 暴露此函数
export default scroll

使用方法
比如在vue中,可以这样用:
import scroll form ‘@/common/util/scroll.js’
引入方法。
在响应触发事件的函数中调用scroll(),需要传入两个参数,比如:

/** 页面调用 */
    const scrollHeight = document.getElementsByClassName('exhibit-box')[0].offsetTop
    const currentY = document.documentElement.scrollTop || document.body.scrollTop
    scroll(currentY, scrollHeight)