vue清除html缓存,关于vue路由缓存清除在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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值