- 34
- 0
求教大神能否实现页面前进请求数据,后退不请求数据,展示之前请求过的数据,包括滚动到跳转前页面的位置,网上铺天盖地的keep-alive方案在移动端会出现各种bug,不行,pc端试没问题。
需求是记录上次页面点的位置,包括分页列表滑动到的位置,tab等
- 共 0 条
- 全部回答
-
曾爱曾喜曾忧伤 普通会员 1楼
在 Vue 应用中,要实现页面前进请求数据、后退不重新请求且保持之前浏览状态(包括滚动位置等),可以利用 Vue Router 的导航守卫(Navigation Guards)以及 Vue 自身的组件状态管理。
以下是一个基本的实现思路:
- 在路由配置(router.js)中设置全局前置守卫(beforeEach):
```javascript import router from './router' import store from './store' // 假设你使用了 Vuex
router.beforeEach((to, from, next) => { if (to.meta.keepAlive && from.meta.keepAlive) { // 根据 meta 中的 keepAlive 属性判断是否缓存 // 后退时,直接从 store 或者Vuex的state中获取数据,无需再次请求 if (from.name === to.name) { next() return } }
// 前进或首次进入该页面时,发起数据请求 if (to.meta_needRequest) { store.dispatch('fetchData', to.params) // 假设你有一个 fetchData action 来获取数据 .then(() => { next() }) } else { next() } }) ```
- 在你的组件内部,利用 Vue 的
keep-alive特性来缓存组件状态:
```html
`` 3. 对于滚动位置的记录和恢复,可以在组件的activated钩子函数(对于被 keep-alive 缓存的组件)或mounted` 钩子函数(对于新创建的组件)中进行处理:javascript export default { activated() { // 从 sessionStorage 或 Vuex 中恢复滚动位置 let scrollTop = sessionStorage.getItem(`${this.$route.path}_scrollTop`) if (scrollTop) { document.documentElement.scrollTop = scrollTop } }, beforeRouteLeave(to, from, next) { // 在离开当前页面时,存储滚动位置 sessionStorage.setItem(`${from.path}_scrollTop`, document.documentElement.scrollTop) next() }, }以上代码示例仅供参考,具体实现可能需要根据你的项目实际情况进行调整。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
