vue-router中scrollBehavior的巧妙用法
2018-07-09 11:31
756 查看
问题:使用keep-alive标签后部分安卓机返回缓存页位置不精确问题
解决方案:
<div id="app"> <keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view> </div> const router = new Router({ scrollBehavior(to, from, savedPosition) { if (savedPosition && to.meta.keepAlive) { return savedPosition; } return { x: 0, y:0 }; }, });
2. 页面返回出现空白屏问题
问题
【前提】:iOS设备
【步骤】: 页面A是个列表很长-->滑到页脚的时候点击跳转之后到页面B--->再返回A页面
--->屏幕会出现空白遮罩层--->手指轻触屏幕滑动--->遮罩层消失
解决方案一
在接口请求成功后的回调操作完成后进行该操作,例如
// fetchCourseList是一个封装好的Promise请求 fetchCourseList().then(({ data: courses }) => { this.courses = courses; }).then(() => { setTimeout(() => { window.scrollTo(0, 1); window.scrollTo(0, 0); }); });
该方案的弊端: 每个页面都需要做这样的处理,不推荐使用。
解决方案二(推荐)
使用scrollBehavior中的异步滚动操作
const router = new Router({ scrollBehavior(to, from, savedPosition) { // keep-alive 返回缓存页面后记录浏览位置 if (savedPosition && to.meta.keepAlive) { return savedPosition; } // 异步滚动操作 return new Promise((resolve) => { setTimeout(() => { resolve({ x: 0, y: 1 }); }, 0); }); }, });
该方案直接在路由进行处理,兼容每个页面并且页面加载完后并也不会产生1px的滚动位置。
总结
以上所述是小编给大家介绍的vue-router中scrollBehavior的巧妙用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- VueRouter导航守卫用法详解
- vue-router各个属性的作用及用法
- vue-router用法
- Vue页面跳转$router.push 的用法
- Vue-router(vue2.0)用法示例
- vue-router各个属性的作用及用法
- 对vue2.0中.vue文件页面跳转之.$router.push的用法详解
- vue-router路由的配置及用法
- 【vue】vue-router的用法
- vue-router的详细用法
- Vue-Router模式和钩子的用法
- vue-cli快速构建工程 ElementUI axios router 引入使用
- 从零构建 vue2 + vue-router + vuex 开发环境到入门,实现基本的登录退出功能
- 详解基于vue-router的动态权限控制实现方案
- vue-router 基本使用
- vue-router中注意单词
- Vue-loader 的巧妙玩法
- 从零搭建vue工程(vue-router,webpack)
- vue的CDN用法
- 路由vue-router基础