位置: IT常识 - 正文

vue跳转页面后返回不刷新且记录历史滚动条停留位置 (实现了根据不同页面来设置是否刷新记录的功能)(vue 跳转页面)

编辑:rootadmin
vue跳转页面后返回不刷新且记录历史滚动条停留位置 (实现了根据不同页面来设置是否刷新记录的功能) 一、页面返回后不刷新        1.在路由(router/index.js)中,对不刷新的页面设置:meta: { keepAlive: true //true为需要缓存,false为不需要缓存(不需要的也可以不加) },        2.在app.vue中设置:<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>

推荐整理分享vue跳转页面后返回不刷新且记录历史滚动条停留位置 (实现了根据不同页面来设置是否刷新记录的功能)(vue 跳转页面),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue点击页面跳转,vue页面跳转原理,vue跳转当前页面,vue页面跳转原理,vue实现跳转页面,vue页面内跳转,vue页面内跳转,vue 跳转页面,内容如对您有帮助,希望把文章链接给更多的朋友!

这时返回就不会触发created和mounted

二、记录滚动条位置,并在页面显示时设置它:        1.在data中定义scrollTop: 0,        2.挂载: //离开路由之前执行的函数,可用于页面的反向传值,页面跳转。 beforeRouteLeave(to, from, next) { console.log("1212-beforeRouteLeave") // 记录滚动条位置 this.scrollTop = document.documentElement.getElementsByClassName("itemBoxs")[0].scrollTop || 0; //组件写法 this.scrollTop = document.documentElement.getElementById('app').scrollTop || 0; //全局写法 console.log("this.scrollTop", this.scrollTop) next() }, // 组件激活时触发 activated() { // 还原滚动条位置 console.log("1212-activated") document.getElementsByClassName("itemBoxs")[0].scrollTop = this.scrollTop || 0; //组件写法 document.getElementById('app').scrollTop = this.scrollTop || 0; //全局写法 },

以上就实现了返回页面后滚动条记忆的功能啦!

vue跳转页面后返回不刷新且记录历史滚动条停留位置 (实现了根据不同页面来设置是否刷新记录的功能)(vue 跳转页面)

如果想实现分情况决定是否记忆滚动条以及刷新组件数据,请继续往下看:

在上述keep-alive的基础上1.定义全局变量(不要在data中定义!!!)

var isRefresh = false; //定义是否需要刷新

注: 之所以在定义全局变量isRefresh而不在data里定义是因为当生命周期进入beforeRouteEnter的时候,此时当前页面还没有被mounted,因此我们是获取不到当前实例this的指向的,变量值也取不到。

2.定义beforeRouteEnter //路由进入前判断是否重新加载还是缓存 beforeRouteEnter(to, from, next){ if(from.name == 'textbookModeSelection'){ //哪个页面 进入需要刷新 isRefresh = true; //需要刷新 }else{ isRefresh = false; } next() },3.定义activated// 组件激活时触发 activated() { if(isRefresh) { //刷新 this.chooseCourseIndex = null; //清空需要的数据 document.getElementsByClassName("itemBoxs")[0].scrollTop = 0; //置顶滚动条 this.init(); //调用获取数据方法 }else{ //不刷新 还原滚动条位置 document.getElementsByClassName("itemBoxs")[0].scrollTop = this.scrollTop || 0; }

注: keep-alive之后不会执行created,mounted钩子了,在activated中判断需要刷新之后,将列表数据初始化,发起请求即可,不刷新时则返回到列表记录的滚动条的位置

4.定义beforeRouteLeave//路由离开前执行beforeRouteLeave(to, from, next) { // 记录滚动条位置 this.scrollTop = document.documentElement.getElementsByClassName("itemBoxs")[0].scrollTop || 0; next() },

完成!

本文链接地址:https://www.jiuchutong.com/zhishi/297302.html 转载请保留说明!

上一篇:HTML唱吧导航栏(唱吧地图)

下一篇:如何使用ssh密钥的方式实现无密码scp传输文件(ssh怎么带密码)

  • 采购成本和销售费用区别
  • 机票的电子发票和行程单有什么区别
  • 展览服务费进项可以抵扣吗
  • 货物运输代理服务
  • 小规模纳税人税率2023年是多少
  • 软件委托开发合同印花税
  • 托管物资账务处理流程
  • 行政相对人和行政管理相对人的区别
  • 天猫开发票需要确认收货吗?
  • 开具增值税专用发票怎么开
  • 营改增后工业企业税率是多少?
  • 计提税金和缴纳税金的会计分录
  • 报销款冲抵其他应收款怎么做账?
  • 票据再质押
  • 生产人员社保怎么做账
  • 折旧计算所得税吗
  • 微信支付宝余额为零的表情包
  • 超市预付卡发票怎么开
  • 职工教育经费的扣除限额
  • 损益类科目在期末均需转入什么科目
  • 华为鸿蒙harmonyos刷机
  • 注册表被恶意锁定怎么恢复正常
  • 鸿蒙系统小艺怎么改声音
  • 应付票据开出票据的会计分录
  • php bcmul
  • 公司帮员工买社保能扣税吗
  • linux网络接口状态命令
  • Discuz!X中SESSION机制实例详解
  • 无形资产的摊销年限不得低于多少年
  • 刚收到的假发怎么处理
  • 退货的增值税专票怎么开
  • 长期股权投资初始计量和后续计量的区别
  • 46 个非常有用的成语
  • 企业亏损还需要交增值税吗
  • php框架实例
  • php str_split
  • 在建工程完成后转入什么科目
  • 钢琴块小游戏在线玩
  • promise thenable
  • javascript手机上
  • php解释器工作流程
  • 残保金是用人单位还是用工单位承担
  • 建立分公司流程
  • 营业执照更换法人需要哪些手续
  • 其他业务成本如何结转
  • python mad
  • python的utils模块
  • 主营业务成本应交税费
  • 支付宝支付凭证在哪里查
  • 投资者控股性质
  • 自行建造的固定资产达到预定可使用状态
  • 应付账款主要账户有哪些
  • 企业不需要交残保金吗
  • 科目余额表如何看
  • 给客户买的礼品要交税吗
  • 劳动关系与劳务关系的联系与区别
  • 费用票可以抵扣多少企业所得税
  • 因企业增资而产生的费用
  • 产品销售费用是什么科目
  • 房租押金不退如何处理
  • 试运行收入冲减哪个项目
  • 存款利息收入是否缴纳增值税
  • Windows Server 2003将于7月14日停服 想用收费
  • win8系统如何关机
  • linux命令合集
  • ebr.ahrcu
  • vista和win10
  • 打开win七
  • linux dhcpv6
  • 如何在linux shell关闭443端口
  • 控制面板win8在哪里
  • 一个简单的小实验
  • 支持向量机
  • 猫的游戏视频
  • android editText inputType 各个字段的含义
  • jquery绑定click的方法有几种
  • 减免所得税额怎么计算出来的
  • 汽车销售顾问有前途吗
  • 税务局实地核查内容
  • 发票开具显示获取纳税人基础信息失败,请退出?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设