网站首页 > 博客文章 正文
业务场景:一客户手机端界面,一些数据是通过参照界面(界面:referList)选择数据,然后将数据带到本界面(界面:detail),通过路由跳转时每次跳转都会返回到页面顶端,对客户使用非常不友好。
解决思路:路由离开时,将页面位置加入缓存中,再次返回时读取缓存中页面位置,然后赋值到页面。
代码如下:
<script>
export default {
beforeRouteLeave(to, from, next){
//记录离开页面的位置
let position = window.scrollY;
if (position == null){
position = 0;
}
//加入到缓存
let dataStorageHo = {position:position}
this.$store.dispatch('UPDATE_STORAGE', {
storageData:dataStorageHo
});
//必须要加这个,进行下一个钩子函数
next();
},
watch:{
'$route' (to, from) {
//返回到本页面时
if (to.name === 'detail') {
this.datatype = this.$store.state.storage.storageData||0;
let position = this.datatype.position||0;
//将缓存位置赋值过来定位
window.scroll(0, position);
}
}
}
}
</script>
缓存使用的是storage,同时界面加了keep-alive:
<template>
<div>
<keep-alive>
<router-view></router-view>
</keep-alive>
</div>
</template>
- 上一篇: 三种方法实现Vue路由跳转时自动定位在页面顶部
- 下一篇: 有限在线用户的场景中,前后端分离是多此一举
猜你喜欢
- 2024-10-21 IntersectionObserver: 教你如何实现一个Vue无限滚动的组件
- 2024-10-21 支持服务器端渲染的移动端Vue组件——NutUI
- 2024-10-21 循序渐进Vue+Element 前端应用开发(6)—常规Element界面组件使用
- 2024-10-21 vue动态路由(支持嵌套路由)和动态菜单UI开发框架,无偿源码
- 2024-10-21 1小时搞定卡片拖拽、自动排列交换位置、拖拽数据存取
- 2024-10-21 如何使用 vue + intro 实现后台管理系统的新手引导
- 2024-10-21 零基础入门vue开发(vue开发步骤)
- 2024-10-21 前端路由与vue-router的基本用法(前端路由实现的两种方式)
- 2024-10-21 Electron-vue客户端开发总结(electron-vue官网)
- 2024-10-21 史上最全 vue-router 讲解 !!!(vue,router)
你 发表评论:
欢迎- 367℃用AI Agent治理微服务的复杂性问题|QCon
- 358℃初次使用IntelliJ IDEA新建Maven项目
- 357℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 351℃Maven技术方案最全手册(mavena)
- 348℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 346℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 345℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 342℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)