keep-alive
有时候我们不希望组件被重新渲染影响使用体验;或者处于性能考虑,避免多次重复渲染降低性能。而是希望组件可以缓存下来,维持当前的状态。这时候就可以用到keep-alive组件。
官网解释:<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<keep-alive> 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。 当组件在 <keep-alive> 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。 在 2.2.0 及其更高版本中,activated 和 deactivated 将会在 <keep-alive> 树内的所有嵌套组件中触发。 主要用于保留组件状态或避免重新渲染
应用场景
如果未使用keep-alive组件,则在页面回退时仍然会重新渲染页面,触发created钩子,使用体验不好。 在以下场景中使用keep-alive组件会显著提高用户体验,菜单存在多级关系,多见于列表页+详情页的场景如:
- 商品列表页点击商品跳转到商品详情,返回后仍显示原有信息
- 订单列表跳转到订单详情,返回,等等场景。
keep-alive的生命周期
- 初次进入时:created > mounted > activated;退出后触发 deactivated
- 再次进入:会触发 activated;事件挂载的方法等,只执行一次的放在 mounted 中;组件每次进去执行的方法放在 activated 中
项目实践
1.更改App.vue
<div id="app" class='wrapper'>
<keep-alive>
<!-- 需要缓存的视图组件 -->
<router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
<!-- 不需要缓存的视图组件 -->
<router-view v-if="!$route.meta.keepAlive"></router-view>
</div>
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钩子时重新定位到原有位置。 具体设计思路:
- 在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)
欢迎在下方留言讨论,小郭将与你一起成长,想看更多内容可关注同名公众号“一郭鲜”
推荐阅读:小米手环3隐藏功能
-
概念车量产?吉利新车搭双10.25英寸屏,配
自主品牌中,吉利汽车是当之无愧的老大,无论是产品、还是销量,似乎永远都是走在最前面的,2018年,吉利汽车产销突破150万辆,可以说这是所有自主品牌都无法企及的...
2019-10-17 -
蔚来欲融资50亿被否认、塔塔正为捷豹路虎寻找
针对“蔚来汽车正与浙江湖州市吴兴区洽谈一笔超50亿元的融资意向,同时前者将在吴兴区落户一个20万辆年产能的工厂。”的消息,10月16日,湖州市吴兴区委宣传部一位...
2019-10-17 -
续航里程400公里 沃尔沃XC40纯电动版正
[懂车帝原创 产品] 10月17日(北京时间),沃尔沃品牌首款纯电动车(Polestar为独立品牌)——XC40纯电版车型正式亮相,新车基于CMA架构打造而来,...
2019-10-17 -
国产汽车哪家强?领克03、红旗H5、传祺GA
轿车一直是乘用车市场上的霸主,超高的颜值与良好的舒适性一直备受欢迎。随着时间与技术的积累,自主品牌凭借高性价比与越来越可靠的产品获得了国内消费者的认可。今天我们...
2019-10-17 -
实地探店:新轩逸没有优惠;新昂克赛拉并不热门
在现时网络时代,不少有购车打算的消费者通过网络就可以了解到十分全面的资料了。但是,若想要了解到购车的细致条例,其实依然去到4S店才能清楚,甚至4S店还呈现出与网...
2019-10-17 -
新款雷克萨斯RX300到店实拍 外观科技前卫
新款雷克萨斯RX在8月8日正式开启预售,今天给大家要聊的就是新款雷克萨斯RX300的到店实拍,新车除了新增RXL加长版车型外,在外观和内饰也进行了一定的改变,不...
2019-10-17 -
20多万就能入手!奥迪Q3领衔,四款大力度打
谁都想用最便宜的价格买到自己心仪的车,但不少车型在上市之初没有优惠,且定价过高,或许是为了提高品牌的调性,或是为了先高价出售一波以赢取更大利润。万变不离其宗,不...
2019-10-17 -
请对号入座,90后能开上这4款车,就算成功了
我们总是感叹时间过得很快,这是没法改变的事情,一眨眼的功夫,如今最大的90后已经奔三,小孩说不定都有了两个,但对于这些90后来说,什么样才能算是成功?我们以汽车...
2019-10-17