位置: 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怎么带密码)

  • 文化传媒公司的税种及税率
  • 增值税专用发票抵扣期限
  • 公司法人已变更,前法人被失信
  • 政府补助是否可以加计抵扣
  • 增值税发票如何作废流程
  • 房地产购买材料财务报销单上怎么写
  • 物流公司主营业务范围
  • 收回已作为坏账准备的应收账款会计分录
  • 税前扣除的职工福利费标准
  • 存货换入无形资产考虑增值税
  • 物业 免物业费
  • 股东取得利息收入如何纳税
  • 缴纳补充公积金的外企
  • 企业开发票的人员要经过培训吗?
  • 审核发票的要素
  • 机器设备的拆除方法
  • 受让无形资产是什么意思
  • 长期待摊费忘记摊了怎么办
  • 收入是零招待费怎么汇算
  • 50万股份分红
  • 白银及其制品出自哪里
  • 企业计提的工资如何算
  • 欧拉操作系统和龙蜥哪个好用
  • 研发销售型企业
  • 王者荣耀中张飞的台词
  • 银行承兑汇票质押贷款骗局
  • 小微企业所得税怎么算
  • 工程结算需要哪些施工方案
  • 如何进行抵债资金管理
  • 开出转账支票补付款项
  • 使用php进行mysql数据库编程的基本步骤
  • 车辆购置税退税计算
  • 个体工商户筹集资金的难易程度
  • 我国中小企业成本管理现状
  • 随机梯度下降算法优缺点
  • mysqldump 导出数据
  • calc下载
  • 小微企业自己记账怎么算
  • 在建工程转固定资产会计科目
  • 资产负债表不能有负数吗
  • 销售部门发生的商品维修费
  • 银行承兑汇票回头背书
  • 增值税专用发票查询系统官方网站
  • 非金融企业之间的借款合同要交印花税吗
  • 咨询服务业优惠政策
  • 个人所得税要计入管理费用吗
  • 房地产公司分立 土地转移
  • 多栏式日记账核算组织程序优缺点
  • 公户转私户的钱会退回吗
  • 建筑工程公司的经营范围有哪些
  • 冲销销售收入分录
  • 期末自动结转期间损益
  • 购买新发票的时候要带旧发票去吗?
  • 加计扣除怎么申报
  • 如何监测和优化电池寿命
  • mysql的表文件在哪
  • win7自带播放器怎么打开
  • mac更换软件图标
  • linux系统啥样
  • centos用途
  • centos锁定屏幕命令
  • 深度技术win10怎么样
  • 修改windows版本
  • win8恢复出厂设置找不到恢复环境
  • w8系统ie浏览器在哪
  • Win10系统下怎么设置按Win+E进入计算机的图文教程
  • linux小技巧
  • 防火墙ddos攻击防范
  • windows 10 build 21354
  • Node.js中的什么模块是用于处理文件和目录的
  • mark一下怎么用
  • unity3d cant add script
  • js中的date函数
  • javascript如何定义一个函数
  • 水电费加1
  • 广东税务局账号登录
  • 朝阳区下面分几个区
  • 江西省税务局公众号
  • 车船使用税是什么样的单子
  • 粮食部门是不是国家机关
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设