vue在返回上一页的时候执行this.$router.go(-1) ,默认会让上一页重新执行一遍生命周期。

有时候我们不希望组件被重新渲染影响使用体验;或者处于性能考虑,避免多次重复渲染降低性能。而是希望组件可以缓存下来,维持当前的状态。这时候就可以用到keep-alive组件。
<keep-alive 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition 相似,<keep-alive是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。 当组件在 <keep-alive内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。 在 2.2.0 及其更高版本中,activated 和 deactivated 将会在 keep-alive 树内的所有嵌套组件中触发。 主要用于保留组件状态或避免重新渲染

应用场景

如果未使用keep-alive组件,则在页面回退时仍然会重新渲染页面,触发created钩子,使用体验不好。 在以下场景中使用keep-alive组件会显著提高用户体验,菜单存在多级关系,多见于列表页+详情页的场景如:

  • 1商品列表页点击商品跳转到商品详情,返回后仍显示原有信息
  • 2订单列表跳转到订单详情,返回,等等场景。

keep-alive的生命周期

初次进入时:created > mounted > activated;退出后触发 deactivated
再次进入:会触发 activated;事件挂载的方法等,只执行一次的放在 mounted 中;组件每次进去执行的方法放在 activated 中

配置

  • 在需要数据留存的路由添加项:

meta:{
keepAlive:true

}

{ path: '/user/home', name: 'userhome', component: UserHome, meta: { keepAlive: true } }, //值为true需要缓存,为false不需要缓存
  • 然后在router-view页面判断页面留存路由参数:
        <keep-alive><router-view v-if="$route.meta.keepAlive"></router-view>    //留存数据方法</keep-alive><router-view v-if="!$route.meta.keepAlive"></router-view> //不留存数据方法

被keep-alive包裹的动态组件(页面),在组件不活动时,会缓存它们的组件实例,而不是销毁它们。

  • 缓存页面多出两个钩子函数,用于显示和隐藏该缓存的页面时触发
// activated是页面激活后的钩子函数,一进页面就会触发activated () {// 显示时console.log(1)},// deactivated 离开页面的钩子函数,一离开页面就会触发deactivated () {// 不显示时console.log(2)},

3 更改 beforeEach钩子

这一步是为了清空无用的页面缓存。 假设现在A、B两个页面都开启的缓存:

  • 若第一次进入A页面后退出,再次进入页面时,页面不会刷新。这和目前的业务逻辑不符。我们想要的结果是A页面前进后返回,页面保持不变,而不是退出后重新进入保持不变。
  • 在进入过A页面后进入B页面,经过测试后发现,B页面竟然会显示A页面的缓存,尽管url已经改变
    为了解决这个问题,需要判断页面是在前进还是后退。 在beforeEach钩子添加代码:
let toDepth = to.path.split('/').length
let fromDepth = from.path.split('/').length
if (toDepth < fromDepth) {// console.log('back...')from.meta.keepAlive = falseto.meta.keepAlive = true
}

记录页面滚动位置

keep-alive并不会记录页面的滚动位置,所以我们在跳转时需要记录当前的滚动位置,在触发activated钩子时重新定位到原有位置。 具体设计思路:

  • 在deactivated钩子中记录当前滚动位置,使用localStorage:
deactivated () {window.localStorage.setItem(this.key, JSON.stringify({listScrollTop: this.scrollTop}))
}
  • 在activated钩子中滚动:
this.cacheData = window.localStorage.getItem(this.key) ?JSON.parse(window.localStorage.getItem(this.key)) : null
$('.sidebar-item').scrollTop(this.cacheData.listScrollTop)

vue-router配置路由实现返回上一页,上一页页面数据留存相关推荐

  1. Vue Router 实现路由控制实战

    本文是我在学习过程中记录学习的点点滴滴,目的是为了学完之后巩固一下顺便也和大家分享一下,日后忘记了也可以方便快速的复习. Vue Router 实现路由控制实战 前言 一.什么是单页面应用及实现前端路 ...

  2. 面试考问Vue Router 的路由模式,这个回答令我直接出局!

    HR力荐了一个工作 4 年,目前年薪 40W+ 的候选人. 看他简历,从 HTML,CSS,JavaScript ,Vue.js ,再到React 一个都不缺,跨平台PC.移动端.小程序也都接触过,像 ...

  3. 你真的理解 Vue Router 的路由模式吗?

    HR力荐了一个工作 4 年,目前年薪 40W+ 的候选人. 看他简历,从 HTML,CSS,JavaScript ,Vue.js ,再到React 一个都不缺,跨平台PC.移动端.小程序也都接触过,像 ...

  4. 面试考问Vue Router 的路由模式,这个回答令我直接出局~

    HR力荐了一个工作 4 年,目前年薪 40W+ 的候选人. 看他简历,从 HTML,CSS,JavaScript ,Vue.js ,再到React 一个都不缺,跨平台PC.移动端.小程序也都接触过,像 ...

  5. vue 跳转路由后返回上一页还是当前页面,但是路由地址有改变(已解决)

    问题描述: 在开发vue项目的时候,涉及到路由跳转,前面的一顿操作配置路由的都很舒畅,跳转返回啥的都没问题.问题是啥呢,我在做个有视频播放的页面的时候,由于代码是参考别人的(狗头),导致在首页点击跳转 ...

  6. vue router children 路由变了 组件没变_Vue.js从零开始——路由(2)

    因为一些原因,我断更了几天时间,因为要准备面试 + 不在家,抱歉大家! 题图是一个大概的 Vue 模块化项目组成,当然因为我从网上找的,所以可以忽略当中的 Bulma,这其实是一个 CSS 框架,往简 ...

  7. Vue Router 命名路由、(嵌套)命名视图

    命名路由 在Vue Router中 除了 path 之外,还可以为任何路由提供 name. const routes = [{path: '/user/:username',name: 'user', ...

  8. vue router 的路由传参 params 和 query 的 区别

    1. 不带参数<router-link :to="{name:'home'}"> <router-link :to="{path:'/home'}&qu ...

  9. 注意避坑,Vue Router 4: 路由参数在 created/setup 时不可用

    有梦想,有干货,微信搜索 [大迁世界] 关注这个在凌晨还在刷碗的刷碗智. 本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考 ...

最新文章

  1. Ubuntu下firefox启动问题
  2. 什么叫基于web的网站_什么叫响应式网站?响应式网站模板教程
  3. oracle节点1关闭节点2的集群,[Oracle] Oracle两个节点分裂,识别不到对方节点的状态...
  4. 手写springboot_Spring Boot 入门教程 | 图文讲解
  5. 一文介绍备机重建各种方法的实现机制
  6. (实用篇)浅谈PHP拦截器之__set()与__get()的理解与使用方法
  7. java set取最大最小_Java中取得数组中最大(小)元素的几种实现方法
  8. 【Spring】Spring Eureka Client 注册报 registration status: 204
  9. 利用.htaccess绑定域名到子目录
  10. java invoke 返回类型_java-控制器处理程序方法支持的返回类型
  11. Ubuntu下hadoop2.4搭建集群(单机模式)
  12. TS Moly Lubricants TSMoly
  13. 《系统集成项目管理》第一章 信息化知识
  14. SQL Server 2000安装教程
  15. Latex语法学习05:代码表格的制作
  16. 用c语言编程航空售票管理系统,百分求以下代码-仓库管理系统或航空售票系统用C语言实现,最好加有 爱问知识人...
  17. R语言ggplot2可视化格式化轴标签:用逗号格式化ggplot2轴标签、在轴标签数值中加入符号标签(货币符号)
  18. macbook 唤醒后不能输入密码
  19. html:link-icon标签引入网站小图标favicon.ico
  20. 1000套微信小程序源码源代码带后台带运行截图预览图学习资料网盘下载

热门文章

  1. ceph分布式存储-常见 PG 故障处理
  2. 考研视频有点难,以后继续早上锻炼
  3. 一个汉字占用多少个字节?不同的编码方式
  4. NTC电阻短路(高温)电池未停止充电分析
  5. 高德地图上绘制城市名字和带涟漪的点标记
  6. 治疗贫血的几款食疗方
  7. Clickhouse其它类型表引擎(Live View、Null、URL)
  8. 赠与今年的大学毕业生 - 胡适
  9. 找出知晓秘密的所有专家(leetcode 2092)
  10. 智慧公厕解决方案,光明源智慧公厕解决方案全解