如何使用jquery将ajax响应存储在浏览器缓存中
How to store the ajax response in browser cache with jquery
我正在尝试将ajax响应存储在浏览器缓存中。我知道只为类似url的(example.com)存储它,但我想存储具有类似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);
}
};
请任何人帮我解决这个问题。
通过从MDN我认为你做错了。如果要将ajax响应CACHE
属性缓存到true
在ajax调用中,还要确保从服务器提供正确的缓存过期标头。而且【来自MDN】
永远不要使用传统的GET参数访问缓存的文件(就像其他缓存的一样-page.html?parameterName=值)。这将使浏览器绕过缓存并尝试获取它来自网络。要链接到具有在JavaScript中解析的参数的缓存资源,请使用链接的散列部分中的参数,例如其他缓存的page.html#什么?parameterName=值。
如果您正在寻找本地存储〔键值存储〕
globalStorage['cache_1'].setItem("key",data);
相关文章:
- image.onload事件和浏览器缓存
- 微软边缘浏览器缓存中的RESTful Angular应用程序
- 使用查询字符串方法清除浏览器缓存
- 浏览器缓存PHP生成的CSS和Javascript文件
- 阻止浏览器缓存上载的图像
- 停止浏览器缓存文本文件
- 从浏览器缓存渲染的页面
- 如何强制从浏览器缓存重新加载当前页面
- 在jquery中按Ctrl+F5清除浏览器缓存
- 如何在注销后从服务器重新加载angular应用程序,而不使用浏览器缓存
- 有没有任何方法可以使用js清除浏览器缓存,至少是我的域相关文件
- mvc项目中javascript和css文件的浏览器缓存
- 阻止浏览器缓存AJAX请求
- 如何使用jquery将ajax响应存储在浏览器缓存中
- 有没有办法防止浏览器缓存滚动位置和缩放级别等值
- 咖啡脚本和浏览器缓存
- 使用 AJAX 提交时使浏览器缓存表单数据
- 检查对象是否适合浏览器缓存
- 浏览器缓存是否知道javascript xmlhttp请求
- $('#textboxId').val() 返回旧值(浏览器缓存问题)