小编给大家分享一下vue中keep-alive如何实现列表页缓存,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
网站建设哪家好,找创新互联公司!专注于网页设计、网站建设、微信开发、小程序制作、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了五大连池免费建站欢迎大家使用!需求:
商品列表页面浏览,进入商品详情,点击返回仍然是之前浏览的位置
实现:
使用 vue
的 keep-alive
的 include
属性给组件做动态缓存,从详情页返回不变,从其他页面进入列表页则刷新
加需要缓存的列表页面定义一个数据集在 vuex
state:{ pageListArr:[] }
列表页的 name
为 proList
,详情页的 name
为 proDetail
,只有 PageListArr
包含的字段才会被缓存,如 pageListArr.push("proList")
思路:
在页面初始化前,获取来源页面的 name
和要去加载页面的 name
.
在这里使用全局导航守卫
router.beforeEach((to, from, next) => { // 来源页面name -> from.name // 去往页面name -> to.name // 如果要跳转的页面为商品列表,且不是从商品详情返回或者跳转 if(to.name===`proList`&&from.name!==`proDetail`){ pageListArr.push(`proList`) } // 来源为商品页面返回列表页面 if(to.name===`proList`&&from.name===`proDetail`){ console.log(`不做处理`) } })
当多个不同的列表页面需要设置缓存时,如分类商品列表,活动商品列表
需要先判断 pageListArr
是否已缓存某些页面,只有从商情详情返回已缓存的列表页才是无刷新,未缓存的列表页面仍然需要新缓存
以上是“vue中keep-alive如何实现列表页缓存”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联成都网站设计公司行业资讯频道!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。