我正在尝试将ajax响应存储在浏览器缓存中。我知道存储它只为url喜欢(example.com),但想要存储的数据有网址喜欢(example.com?xyz=abc%20efg&mno=hjk
)。
我的代码:
beforeSend: function () {
var addC=url; // I want to add data also with this url
console.log(addC);
if (localCache.exist(addC)) {
printRes(localCache.get(url));
console.log("cached values");
return false;
}
return true;
},
和
var localCache = {
data: {},
remove: function (url) {
delete localCache.data[url];
},
exist: function (url) {
return localCache.data.hasOwnProperty(url) && localCache.data[url] !== null;
},
get: function (url) {
console.log('Getting in cache for url' + url);
return localCache.data[url];
},
set: function (url, cachedData, callback) {
localCache.remove(url);
localCache.data[url] = cachedData;
if ($.isFunction(callback)) callback(cachedData);
}
};
请任何人帮助我解决这个问题。
发布于 2013-11-23 20:29:05
通过从MDN读取docs,我认为你做错了。如果希望在ajax调用中将ajax响应CACHE
属性缓存到true
,还要确保从服务器提供正确缓存过期标头。也来自MDN
切勿使用传统的GET参数(如other- cached - page.html?parameterName=value)访问缓存文件。这将使浏览器绕过缓存,并尝试从网络获取缓存。要链接到具有在JavaScript中解析的参数的缓存资源,请使用链接的散列部分中的参数,如other-cached-page.html#whatever?parameterName=value.
如果您正在寻找本地存储键值存储
globalStorage['cache_1'].setItem("key",data);
https://stackoverflow.com/questions/20161703
复制相似问题