【发布时间】:2013-11-23 11:23:59
【问题描述】:
我正在尝试将 ajax 响应存储在浏览器缓存中。我知道只为(example.com)之类的url存储它,但想存储具有url之类的数据(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);
}
};
请任何人帮我解决这个问题。
【问题讨论】:
-
这里问什么?每个 url 只是映射对象中一个值的键,有或没有参数。您是否在问如何将对象转换为 URL 编码的字符串?如果是这样,请查看this question。仍然不确定这是否会正常工作,因为您需要确保 url 参数始终处于正确的顺序...
标签: javascript jquery ajax caching browser-cache