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

下面小编就为大家分享一篇vue2.0路由切换后页面滚动位置不变BUG的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

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

<a href="javascript:;" @click="useRightNow">立即试用</a> <router-link 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的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/pxxxd.html