您的位置: 青财网 > 企业 > 正文

利用Vue中keep-alive,快速实现页面缓存!

2020-11-19 13:02:11来源:阅读:-

keep-alive

有时候我们不希望组件被重新渲染影响使用体验;或者处于性能考虑,避免多次重复渲染降低性能。而是希望组件可以缓存下来,维持当前的状态。这时候就可以用到keep-alive组件。

官网解释: 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 相似, 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。 当组件在 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。 在 2.2.0 及其更高版本中,activated 和 deactivated 将会在 树内的所有嵌套组件中触发。 主要用于保留组件状态或避免重新渲染

应用场景

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

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

keep-alive的生命周期

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

项目实践

1.更改App.vue

2.在路由中设置keepAlive

{

path: 'list',

name: 'itemList', // 商品管理

component (resolve) {

require(['@/pages/item/list'], resolve)

},

meta: {

keepAlive: true,

title: '商品管理'

}

}

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 = false

to.meta.keepAlive = true

}

记录页面滚动位置

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

  1. 在deactivated钩子中记录当前滚动位置,使用localStorage:

deactivated () {

window.localStorage.setItem(this.key, JSON.stringify({

listScrollTop: this.scrollTop

}))

}

  1. 在activated钩子中滚动:

this.cacheData = window.localStorage.getItem(this.key) ?JSON.parse(window.localStorage.getItem(this.key)) : null

$('.sidebar-item').scrollTop(this.cacheData.listScrollTop)


欢迎在下方留言讨论,小郭将与你一起成长,想看更多内容可关注同名公众号“一郭鲜”

推荐阅读:辽车网

滚动推荐
02:11利用Vue中keep-alive,
keep-alive有时候我们不希望组件被重新渲染影响使用体验;或者处[详细]
01:13马云说未来的“五个新”,抓住发展趋
这几年对于我国经济的发展,不断在提出改革,那么改革的方向在马云看来体现[详细]
43:47假如iOS能降级,会发生什么?!
我的第一部苹果手机是iPhone5s,它发售于2013年,搭载了iPh[详细]
38:46Google Chrome 3月起
而取消Chromium的支援,意味着所有基于Chromium的浏览器皆[详细]
46:58Vue单页面的动态组件!
{{title}}B组件[详细]
37:00科技助力跨境贸易便利化 中国平安携
11月9日,由平安集团和招商局集团共同主办的“粤港澳大湾区组合港启动仪[详细]
34:56跟谁学教师秉持热爱,帮助更多孩子更
跟谁学教师秉持热爱,帮助更多孩子更多家庭[详细]