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

亚连
Lepaskan: 2018-05-30 13:56:48
asal
2158 orang telah melayarinya

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

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

<a href="javascript:;" rel="external nofollow" class="btn btn01" @click="useRightNow">立即试用</a>
<router-link class="db" to="/user">个人中心</router-link>
Salin selepas log masuk

useRightNow(){
 if(判断用户存在){
  this.$router.push(&#39;/user&#39;)
 }else{
  this.$router.push("/login")
 }
}
Salin selepas log masuk

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

export default {
  watch:{
   &#39;$route&#39;:function(to,from){
           document.body.scrollTop = 0;
     document.documentElement.scrollTop = 0; 
   }
  }
 }
Salin selepas log masuk

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

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

Angular4集成ng2-file-upload的上传组件

nodejs acl的用户权限管理详解

nodejs实现解析xml字符串为对象的方法示例

Atas ialah kandungan terperinci vue2.0路由切换后页面滚动位置不变BUG的解决方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan