我是靠谱客的博主 愤怒秋天,最近开发中收集的这篇文章主要介绍Vue 单页面页面跳转滚动条记忆问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

问题描述:

        单页面中页面跳转后,二级页面滚动条位置会跟上级页面一致。如首页列表页,进入详情如果详情内容可滚动,滚动条会同首页位置一致。原因vue路由跳转是通过对history.pushState()和history.replaceState()方法模拟来实现的,当调用router.go()或者 router.back()方法的时候就和history.hgo()、history.back()效果一样。但是,不加处理的情况下,组件的滚动行为会跟我们想象的不同

解决方案:

        网上给出了很多解决方案,大多数是页面切换控制scroll位置。但是此处推荐vue官方给出的方案 scrollBehavior 方法,下边给出官方示例

注意: 这个功能只在支持 history.pushState 的浏览器中可用。

const router = new VueRouter({
routes: [...],
scrollBehavior (to, from, savedPosition) {
// return 期望滚动到哪个的位置
return { x: 0, y: 0 }
}
})

更多深入使用方法和场景在此不多赘述。

最后

以上就是愤怒秋天为你收集整理的Vue 单页面页面跳转滚动条记忆问题的全部内容,希望文章能够帮你解决Vue 单页面页面跳转滚动条记忆问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部