vue路由缓存清除在main.js中设置

1.main.js

/* 页面数据缓存 */
var _CACHE_OBJS = {};

function _init_cache(comp, key, cache) {
  var obj = cache[key];
  if (obj !== undefined) {
    comp[key] = obj;
  }
  var deep = typeof comp[key] === 'object';
  comp.$watch(key,
    function (val) {
      //console.log("page " + key + " updated");
      cache[key] = val;
    }, {
      deep: deep
    });
}


var _PAGE_CACHE = {
  /*
   * 初始化页面缓存数据
   * comp: 当前页面component 对象
   * path: 当前页面vue router path
   * data: 需要缓存的数据对象名称,或名称数组
   */
  cache: function (comp, path, data) {
    if (data == '' || data == undefined || data == null) {
      data = restore(comp._data);
    }
    var cache = _CACHE_OBJS[path];
    if (cache === undefined) {
      cache = {};
      _CACHE_OBJS[path] = cache;
    }
    if (typeof data == 'string') {
      _init_cache(comp, data, cache);
    } else {
      var i;
      for (i = 0; i < data.length; ++i) {
        _init_cache(comp, data[i], cache);
      }
    }
    console.log(_CACHE_OBJS, "页面数据缓存");
  },

  /* 清除页面缓存 */
  clear: function (path) {
    delete _CACHE_OBJS[path];
  },

  /* 清空所有缓存数据 */
  reset: function () {
    //console.log("reset page cache");
    _CACHE_OBJS = {};
  },
  /*根据path查看当前页面缓存是否存在*/
  has_cache: function (path) {
    return _CACHE_OBJS[path] !== undefined && !isEmptyObject(_CACHE_OBJS[path]);
  }
};

Vue.prototype.$cache = _PAGE_CACHE;
/* eslint-disable no-new */

var restore = function (vueObject) {
  var result = [];
  for (var index in vueObject) {
    result.push(index);
  }
  return result;
};

var isEmptyObject = function (obj) {
  for (var key in obj) {
    return false;
  }
  return true;
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值