码迷,mamicode.com
首页 > 其他好文 > 详细

vue中使用keepAlive组件缓存遇到的坑

时间:2017-12-27 12:03:08      阅读:551      评论:0      收藏:0      [点我收藏+]

标签:detail   进入   false   http   body   强制   操作   img   用户   

项目开发中在用户由分类页category进入detail需保存用户状态,查阅了Vue官网后,发现vue2.0提供了一个keep-alive组件。
上一篇讲了keep-alive的基本用法,现在说说遇到的坑。
先说项目中的配置
 
在App.vue中的设置
 技术分享图片技术分享图片技术分享图片

在router中增加配置meta
  技术分享图片技术分享图片
 
上面这个设置后发现问题了,从category进入detail页后,状态被保存了,返回的时候保存了用户状态,达到了预期效果
技术分享图片
但问题在于但从category返回到index后,再由index进入category时依然显示是缓存中的页面,此刻页面没有刷新。
返回index后的组件显示如下:
技术分享图片
技术分享图片
   
分析从index再次进入category时,直接读取了缓存的里的页面。
头大。。。。。。。我的目标只是缓存从category进入detail页面,其他的时候不缓存。
 
 
解决方案
在category中启用beforeRouteLeave钩子函数
技术分享图片
beforeRouteLeave中只有从category进入detail时才进行缓存,其他页面都讲category的keepalive设置成false,并销毁此category组件;
 技术分享图片
然而,发现新的问题。。。。。。
第一次操作index--> category ---> detail的时候是理想效果,但当第二次操作返回index后,进行index --> category --> detail --> category时,发现缓存的对象又不对了,从detail返回category时,保存是的第一次进入detail的分类情况。
此刻category的组件显示如下
技术分享图片
 技术分享图片
 
无奈。。。。。对比了第一次和第二次进入页面情况
 
根据vue-router提供的守卫可在路由中启用afterEach路由守卫,在afterEach中进行判断是否第一次进入,非第一次进入页面情况强制刷新一次category页面。 
技术分享图片
 技术分享图片
 
至此终于解决了这个问题。
 
网友提供了其他的解决方案可以参考下,
也可以参考github上关于keep-alive缓存相关的问。

vue中使用keepAlive组件缓存遇到的坑

标签:detail   进入   false   http   body   强制   操作   img   用户   

原文地址:https://www.cnblogs.com/nokelong/p/8124513.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!