摘要:本文将带你了解WEBAPP开发之Vue2开发WebApp滚动条不缓存的问题,希望本文对大家学WebApp有所帮助。
在用Vue2开发webapp的过程中,为了体验更加友好,使用了keep-alive来做页面缓存,当页面跳转时不刷新页面。关于keep-alive官方文档如下:
keep-alive文档
keep-alive主要是起到一种缓存页面的作用,在webapp中不用刷新,从而提高用户体验。但是再项目的实际应用中却遇到了问题。:
滚动条bug
页面的切换,并不会保留原先的滚动条高度。比如,当打开一个新闻客户端,在新闻列表页面,滑了很久找到了一个新闻,点进去看,看完之后再返回列表页,发现滚动条到了顶部,真是气晕。又得重新滑到底部才能接着看。 对于上面的问题,先进行问题分析,为什么会这样呢?我大致的想法是这样,因为vue的路由切换用的是hash的方式,而hash相当于平时所用的锚点,也就是在href属性里添加"#",平时点击一个href="#"的时候,滚动条会自动跳到顶部。解决方案: 在这里,最简单的办法是,当页面跳转的时候,记录该页面滚动条的的高度(最后一次),当页面回来的时候再去取值。 vue-router提供了组件内钩子函数:beforeRouteEnter和beforeRouteLeave,正如其名,vue-router提供的导航钩子主要用来拦截导航,让它完成跳转或取消。有多种方式可以在路由导航发生时执行钩子:全局的,单个路由独享的,或者组件级的。 有了路由钩子函数,就可以再页面切换的时候调整滚动条。 还需要一个存取滚动条高度值的工具,这里直接使用vuex。利用vuex的状态管理来进行滚动条存取。参照官方demo。
store.js
最后,滚动条高度得到了记录保存,
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之WebApp频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号