vue下使用scrollIntoView()进行锚点跳转导致整个页面产生偏移的问题及解决办法

项目场景:

vue项目中存在这样一个需求,一个长页面需要在用户复制好的url链接下进行锚点跳转,定位到url中携带的hash(在生成链接的时候把元素id拼进了url的hash中)的位置处。


问题描述

MDN可以使用这个方来进行页面的滚动,参数如下:
MDN
于是乎我的问题就很好解决了,直接获取要跳转到的锚点所在元素,然后调用scrollIntoView即可,当然,前提是在mounted生命钩子函数中进行操作,代码如下:

mounted () {
    this.$nextTick(() => {
      if (this.$route.hash !== '') {
        let id = this.$route.hash.split('#')[1]
        let el = document.getElementById(id)
        el.scrollIntoView({
          behavior: 'smooth', // 平滑过渡
          block: 'start',
          inline: 'start'
        })
      }
    })
  }

好咧大功告成!不出意外的话就要出意外了
(如果你成功了没啥事的那就不需要往下看了~~)

正常情况下咋一看跳转成功了是不是?别急,咱们尝试一下一个长页面,然后跳转到最底下靠近底部区域的一个锚点,可能会遇到和我一样的问题

如图:
在这里插入图片描述
这里可以看到整个页面往上偏移了,而且往上滚动你会发现最上方的元素会看不到也移不上去啦!糟糕 这个问题可难倒了我这个cv工程师,岂可修!


原因分析:

经过我一番查找我发现了这样一篇文章
在这里插入图片描述
原文链接在这里:https://blog.csdn.net/lvonve/article/details/112782708

看完之后我发现难不成这个scrollIntoView方法有bug不能用不成?难道我要引一个jquery进来操作吗 打咩打咩!
看完之后我发现还有另一个方法提供给大家,如下:

mounted () {
    this.$nextTick(() => {
      if (this.$route.hash !== '') {
        let id = this.$route.hash.split('#')[1]
        let el = document.getElementById(id)
        let page = document.getElementById('***') // ***指你要滚动的锚点的页面父元素
        let height = el.offsetTop // 计算需要向上移动的距离
        page.scroll({
        	top: height,
        	behavior: 'smooth' // 平滑移动
        })
      }
    })
  }

我尝试了上面我说的这个方法之后发现问题仍然存在,说明了不是scrollIntoView的问题,经过一顿查阅之后发现终于发现问题,其实是页面里面的元素的高度超出了我要滚动的元素的高度,导致往下滚动的时候整个页面发生偏移。举个例子,我的项目是左右布局的,左边蓝色部分的高度超出了页面,才会导致这个问题,只要排除了这个超出高度部分的margin或者让它元素高度缩小在页面可见范围内即可解决问题~
在这里插入图片描述


解决方案:

整个页面查找超出页面高度部分,缩小高度即可

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue中解决a标签锚点跳转位置上下偏移的方法有很多种,下面我将介绍几种常用的方法。 1. 使用Vue Router的滚动行为功能。在Vue Router中,可以通过设置scrollBehavior属性来控制页面滚动行为。可以通过给目标路由设置一个滚动偏移量来实现锚点跳转时的位置偏移。例如: ```javascript const router = new VueRouter({ mode: 'hash', // 或者其他模式 ... scrollBehavior(to, from, savedPosition) { if (to.hash) { return { selector: to.hash, offset: { x: 0, y: 100 } // 设置纵向偏移量为100px } } } }) ``` 2. 在目标元素上通过ref属性标记,并通过Vue的$refs来操作元素。在Vue的模板中,可以使用ref属性来标记元素,然后可以通过Vue实例的$refs属性来获取到元素的实例,并进行操作。例如: ```html <!-- 模板 --> <a href="#target" @click="scrollToTarget">跳转到目标</a> ... <div ref="target" id="target">目标元素</div> <!-- Vue 实例中的方法 --> methods: { scrollToTarget() { const targetElement = this.$refs.target // 进行滚动操作,可以通过scrollTop属性或者其他滚动方法来控制滚动位置,再加上偏移量即可 } } ``` 3. 使用第三方库来实现滚动行为。除了Vue Router,还有一些第三方库可以用于处理滚动行为,如vue-scrollto、vue-scroll-behavior等。这些库提供了方便的API,可以轻松地控制滚动位置和偏移量。可以根据具体需求选择合适的库使用。 总的来说,以上是几种常见的在Vue中解决a标签锚点跳转位置上下偏移的方法。具体的使用方式可以根据实际需求选择合适的方法来实现相应的效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值