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

  • 联想拯救者游戏模式怎么开启(联想拯救者游戏本推荐)

    联想拯救者游戏模式怎么开启(联想拯救者游戏本推荐)

  • 红米k40安兔兔跑分多少(红米k40安兔兔多少分)

    红米k40安兔兔跑分多少(红米k40安兔兔多少分)

  • 华为p40怎么退出程序(华为p40怎么退出程序运行)

    华为p40怎么退出程序(华为p40怎么退出程序运行)

  • 收付款二维码发给别人了怎么办(收付款二维码发给别人可以消费吗)

    收付款二维码发给别人了怎么办(收付款二维码发给别人可以消费吗)

  • qq怎么实名认证(腾讯qq怎么实名认证)

    qq怎么实名认证(腾讯qq怎么实名认证)

  • 抖音0播放怎么恢复(抖音播放怎么静音)

    抖音0播放怎么恢复(抖音播放怎么静音)

  • 苹果预约换电池需要多长时间(苹果预约换电池怎么取消)

    苹果预约换电池需要多长时间(苹果预约换电池怎么取消)

  • 苹果手机触感怎么设置(苹果手机触感怎么设置123)

    苹果手机触感怎么设置(苹果手机触感怎么设置123)

  • 电脑不支持5gwifi如何解决(电脑不支持5gwifi用连接线可以吗)

    电脑不支持5gwifi如何解决(电脑不支持5gwifi用连接线可以吗)

  • 朋友圈提醒谁看对方知道吗(朋友圈提醒谁看对方会有特殊通知吗)

    朋友圈提醒谁看对方知道吗(朋友圈提醒谁看对方会有特殊通知吗)

  • 如何在word中编辑图片(如何在word中编辑表格)

    如何在word中编辑图片(如何在word中编辑表格)

  • word图片怎样居中(word中怎样让图片居中)

    word图片怎样居中(word中怎样让图片居中)

  • 手机qq怎么加分组(手机qq怎么增加好友分组)

    手机qq怎么加分组(手机qq怎么增加好友分组)

  • 苹果x怎么设置24小时制(苹果x怎么设置24键盘)

    苹果x怎么设置24小时制(苹果x怎么设置24键盘)

  • 饿了么发票信息在哪里(饿了么发票信息怎么修改)

    饿了么发票信息在哪里(饿了么发票信息怎么修改)

  • 扣扣自动回复怎么关(扣扣自动回复怎么弄)

    扣扣自动回复怎么关(扣扣自动回复怎么弄)

  • 抖音青少年锁密码是什么(抖音青少年密码忘了怎么办)

    抖音青少年锁密码是什么(抖音青少年密码忘了怎么办)

  • 双卡怎么切换流量(双卡怎么切换流量oppo)

    双卡怎么切换流量(双卡怎么切换流量oppo)

  • 荣耀手环4能接电话吗(荣耀手环4能接收微信信息吗?)

    荣耀手环4能接电话吗(荣耀手环4能接收微信信息吗?)

  • 硬盘上的扇区标志在什么时候建立(硬盘上的扇区标志是什么)

    硬盘上的扇区标志在什么时候建立(硬盘上的扇区标志是什么)

  • 如何看微信玩多长时间(怎么知道微信玩了多少天)

    如何看微信玩多长时间(怎么知道微信玩了多少天)

  • oppor15上市时间(oppor15上市时间年月日)

    oppor15上市时间(oppor15上市时间年月日)

  • dsp处理器与mcu的结构上的异同(dsp处理器与其他处理器的本质区别)

    dsp处理器与mcu的结构上的异同(dsp处理器与其他处理器的本质区别)

  • 苹果x能无线充电吗(苹果x无线充电功率)

    苹果x能无线充电吗(苹果x无线充电功率)

  • 小规模纳税人转一般纳税人
  • 资金占用费税前扣除比例
  • 资源税类包括哪些税种
  • 上月有留抵税额本月怎么申报
  • 个人所得税6月底没有退怎办
  • 粗纤维测定仪使用方法
  • 申请100万增值税发票资格
  • 飞机票退票费如何处理账务
  • 高铁票抵扣进项税
  • 异地施工如何缴工会经费
  • 设计、制造
  • 房屋租赁需要交增值税吗
  • 房地产开发公司注册条件
  • 产品质量问题怎么处罚
  • 去年的税还能退吗
  • 宣传费开票属于什么费用
  • 境内公司购买境外公司服务 缴税
  • 库存现金进账单会计分录
  • 销售费用办公费用
  • 固定资产提前报废账务处理
  • 存货发出记账成本最高
  • 滴滴电子发票怎么填写
  • 应收账款零头没有收到如何账务处理
  • 应收账款的内容包括
  • 服务公司收到服务费发票怎么做账
  • 2021年8月现在还能去武汉吗
  • 财务软件税率
  • 如何修复win7系统引导
  • 预付款无法收回账务处理
  • Linux怎么修改账户名
  • 收到退回的保证金利息怎么入账
  • 增值税留抵退税政策2023
  • 财务报表的组成部分
  • 代垫运费增值税怎么算
  • wordpress建网站详细教程
  • 灰狼算法的改进
  • 差额征税收到雇主责任险进项发票能抵扣吗
  • 增值税专用发票的税率是多少啊
  • php100 jquery教程
  • php实现导出带样本的方法
  • 发票确认平台勾选步骤
  • 电子发票冲红后对方能查到吗
  • 财务核算科目核算流程图
  • 公司没业务可以暂停营业吗
  • 织梦怎么改文字
  • SQL SERVER 2000 9003错误的解决方法(只适用于SQL2000)
  • sql2000日志清理
  • 小规模纳税人技术维护费可以抵扣吗
  • 小型微利企业认定标准最新
  • 银行汇票的账务处理例题
  • 农产品委托代销增值税怎么算
  • 小微企业免税销售额怎么填
  • 行政事业单位会计风险来源于日常的会计活动
  • 公司招待费用会计分录
  • 本年利润的计算
  • 案例解析企业所需资金
  • 实收资本实际缴纳要去税务局备案吗
  • 在WINDOWS系统中用鼠标拖动非最大化窗口的标题栏可以
  • winpe.wim怎么安装
  • WZCBDLS.EXE - WZCBDLS是什么进程
  • windowsxp打开注册表
  • win10周年更新版是什么意思
  • winxp开启远程控制
  • ubuntu创建新用户并增加管理员权限
  • centos安装软件教程
  • ip地址xp系统
  • 如何解决xp系统卡顿
  • centos6.5升级到7.5
  • win10系统电脑怎么关机
  • nodejs创建vue
  • python urljoin
  • koa和express的区别
  • 安卓绘制图表
  • 备忘录全部笔记
  • Dojo Javascript 编程规范 规范自己的JavaScript书写
  • 浅谈python 四种数值类型(int,long,float,complex)
  • python中创建自定义函数
  • 租车费为何不能抵扣
  • 仓储物流企业的事故指标
  • 个人所得税法全文完整版2021实施细则
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设