vue移动端项目缓存问题实践记录


Posted in Javascript onOctober 29, 2018

最近在做一个vue移动端项目,被缓存问题搞得头都大了,积累了一些经验,特此记录总结下,权当是最近项目问题的一个回顾吧!

先描述下问题场景:A页面->B页面->C页面。假设A页面是列表页面,B页面是列表详情页面,C页面是操作改变B页面的一些东西,进行提交类似的操作。A页面进入B页面,应该根据不同的列表item显示不一样的详情,从B进入C,也应该根据item的标识比如ID展示不一样的内容,在C页面操作后,返回B页面,B页面数据发生变化。这个时候会有两种情况:

  • C页面操作数据后返回B页面,B页面对应数据应该发生变化。
  • C页面直接点击左上角箭头返回,B页面对应数据不应该发生变化。继续返回A列表页面,换一条数据,继续进入B页面,B页面展示不同内容,进入C页面,C页面刷新展示不同内容

另一种情况发生在写邮件的页面中,添加收件人,选人之后,继续添加,之前添加的联系人应该存在。但是从写邮件页面返回邮件列表再次进入写邮件页面,之前添加过的联系人数据就不应该存在了,这里就涉及到如何处理缓存,何时使用缓存,何时清除缓存的问题了。

目前项目整体结构如下:

<template>
 <div id="app">
  <keep-alive>
   <router-view v-if="$route.meta.keepAlive"></router-view>
  </keep-alive>
  <router-view v-if="!$route.meta.keepAlive"></router-view>
 </div>
</template>

虽然官方提供了include,exclude,可以让我们决定哪些组件使用缓存,哪些不使用缓存,但是并没有解决我们想动态使用缓存的目的,目前我的项目使用了如下两种方式处理缓存:

方式一 ,使用是否使用缓存标识

在路由文件router.js里给每个路由添加meta信息,标识是否使用缓存。

meta: {
  isUseCache: false,//不使用缓存
  keepAlive: true
}

使用方式:

A->B,B不能缓存;B->A,A缓存。

(1)A页面:

beforeRouteLeave(to, from, next) {
 // 设置下一个路由的 meta
 if(to.path=='/B'){
  to.meta.isUseCache = false;
 }
 next();
},
activated(){
  if(!this.$route.meta.isUseCache){
    this.getData();
  }
}

(2) B页面

beforeRouteLeave(to, from, next) {
 // 设置下一个路由的 meta
 if(to.path=='/A'){
  to.meta.isUseCache = true;
 }
 next();
},
activated(){
  if(!this.$route.meta.isUseCache){
    this.getData();
  }
}

方式二,强制清除缓存。

这种方式是从网上找的一种方式,使用了vue内部组件之后,不在支持动态销毁组件,缓存一直存在,只能从源头上下手,清掉缓存。

export const removeCatch = {
 beforeRouteLeave:function(to, from, next){
  if (from && from.meta.rank && to.meta.rank && from.meta.rank>to.meta.rank)
   {//此处判断是如果返回上一层,你可以根据自己的业务更改此处的判断逻辑,酌情决定是否摧毁本层缓存。
     if (this.$vnode && this.$vnode.data.keepAlive)
     {
       if (this.$vnode.parent && this.$vnode.parent.componentInstance && this.$vnode.parent.componentInstance.cache)
       {
         if (this.$vnode.componentOptions)
         {
           var key = this.$vnode.key == null
                 ? this.$vnode.componentOptions.Ctor.cid + (this.$vnode.componentOptions.tag ? `::${this.$vnode.componentOptions.tag}` : '')
                 : this.$vnode.key;
           var cache = this.$vnode.parent.componentInstance.cache;
           var keys = this.$vnode.parent.componentInstance.keys;
           if (cache[key])
           {
             if (keys.length) {
               var index = keys.indexOf(key);
               if (index > -1) {
                 keys.splice(index, 1);
               }
             }
             delete cache[key];
           }
         }
       }
     }
     this.$destroy();
   }
   next();
 }
};

在需要清掉缓存的页面混合引入该js即可。

总结

以上所述是小编给大家介绍的vue移动端项目缓存问题实践记录,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript typeof 用法
Dec 28 Javascript
JavaScript判断一个URL链接是否有效的实现方法
Oct 08 Javascript
JS+DIV实现鼠标划过切换层效果的实例代码
Nov 26 Javascript
JavaScript实现打开链接页面的方式汇总
Jun 02 Javascript
详解Node.js中的事件机制
Sep 22 Javascript
canvas学习之API整理笔记(一)
Dec 29 Javascript
利用Query+bootstrap和js两种方式实现日期选择器
Jan 10 Javascript
用js实现每隔一秒刷新时间的实例(含年月日时分秒)
Oct 25 Javascript
vue项目base64字符串转图片的实现代码
Jul 13 Javascript
从零开始用electron手撸一个截屏工具的示例代码
Oct 10 Javascript
关于RxJS Subject的学习笔记
Dec 05 Javascript
vue实现员工信息录入功能
Jun 11 Javascript
vue 使用vue-i18n做全局中英文切换的方法
Oct 29 #Javascript
Element-UI踩坑之Pagination组件的使用
Oct 29 #Javascript
vue-router权限控制(简单方式)
Oct 29 #Javascript
详解Vue项目在其他电脑npm run dev运行报错的解决方法
Oct 29 #Javascript
Vue项目自动转换 px 为 rem的实现方法
Oct 29 #Javascript
vue 本地服务不能被外部IP访问的完美解决方法
Oct 29 #Javascript
Webstorm2016使用技巧(SVN插件使用)
Oct 29 #Javascript
You might like
PHP下通过file_get_contents的代理使用方法
2011/02/16 PHP
PHP连接SQLSERVER 注意事项(附dll文件下载)
2012/06/28 PHP
php 人员权限管理(RBAC)实例(推荐)
2017/05/24 PHP
用js实现下载远程文件并保存在本地的脚本
2008/05/06 Javascript
Firefox和IE浏览器兼容JS脚本写法小结
2008/07/07 Javascript
JS页面延迟执行一些方法(整理)
2013/11/11 Javascript
简单实用的反馈表单无刷新提交带验证
2013/11/15 Javascript
Javascript中克隆一个数组的实现代码
2013/12/06 Javascript
JavaScript中的style.cssText使用教程
2014/11/06 Javascript
理解javascript模块化
2016/03/28 Javascript
angularJS Provider、factory、service详解及实例代码
2016/09/21 Javascript
js 实现一些跨浏览器的事件方法详解及实例
2016/10/27 Javascript
鼠标经过出现气泡框的简单实例
2017/03/17 Javascript
canvas绘制一个常用的emoji表情
2017/03/30 Javascript
jQuery实现按比例缩放图片的方法
2017/04/29 jQuery
Three.js开发实现3D地图的实践过程总结
2017/11/20 Javascript
微信小程序实现订单倒计时
2020/11/01 Javascript
vue-cli history模式实现tomcat部署报404的解决方式
2019/09/06 Javascript
这样回答继承可能面试官更满意
2019/12/10 Javascript
JS面向对象编程基础篇(一) 对象和构造函数实例详解
2020/03/03 Javascript
Python匹配中文的正则表达式
2016/05/11 Python
Python中pandas模块DataFrame创建方法示例
2018/06/20 Python
python使用opencv驱动摄像头的方法
2018/08/03 Python
bluepy 一款python封装的BLE利器简单介绍
2019/06/25 Python
Django 用户登陆访问限制实例 @login_required
2020/05/13 Python
python实现三种随机请求头方式
2021/01/05 Python
美国最大的网上冲印店:Shutterfly
2017/01/01 全球购物
迷你唐卡软皮鞋:Minnetonka Moccasin
2018/05/01 全球购物
美国LOGO设计公司:The Logo Company
2018/07/16 全球购物
我的求职计划书
2014/01/10 职场文书
转预备党员政审材料
2014/02/06 职场文书
《夏夜多美》教学反思
2014/02/17 职场文书
保护环境倡议书范文
2014/05/13 职场文书
云冈石窟导游词
2015/02/04 职场文书
部门主管竞聘书
2015/09/15 职场文书
Matlab求解数组中的最大值及它所在的具体位置
2021/04/16 Python