vue2.0路由切换后页面滚动位置不变BUG的解决方法

2019-11-16,,,

最近项目中遇到这样一个问题,vue切换路由,页面到顶端的滚动距离仍会保持不变。

<a href="javascript:;" rel="external nofollow" class="btn btn01" @click="useRightNow">立即试用</a>
<router-link class="db" to="/user">个人中心</router-link>
useRightNow(){
 if(判断用户存在){
  this.$router.push('/user')
 }else{
  this.$router.push("/login")
 }
}

解决办法很简单,如下,直接监测watch路由变化,然后将body的滚动距离scrollTop赋值为0。

export default {
  watch:{
   '$route':function(to,from){
           document.body.scrollTop = 0;
     document.documentElement.scrollTop = 0; 
   }
  }
 }

补充: hash模式下才会导致上述问题,history模式下vue官网有更好的处理方法。

以上这篇vue2.0路由切换后页面滚动位置不变BUG的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持北冥有鱼。

您可能感兴趣的文章:

  • Vue引入jquery实现平滑滚动到指定位置
  • vue scroller返回页面记住滚动位置的实例代码
  • vue-scroller记录滚动位置的示例代码
  • vue实现某元素吸顶或固定位置显示(监听滚动事件)
  • 解决Vue页面固定滚动位置的处理办法
  • 详解使用vue-router进行页面切换时滚动条位置与滚动监听事件
  • 解决vue无法设置滚动位置的问题

《vue2.0路由切换后页面滚动位置不变BUG的解决方法.doc》

下载本文的Word格式文档,以方便收藏与打印。