首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用jquery在浏览器缓存中存储ajax响应

如何使用jquery在浏览器缓存中存储ajax响应
EN

Stack Overflow用户
提问于 2013-11-23 19:23:59
回答 1查看 1.3K关注 0票数 0

我正在尝试将ajax响应存储在浏览器缓存中。我知道存储它只为url喜欢(example.com),但想要存储的数据有网址喜欢(example.com?xyz=abc%20efg&mno=hjk)。

我的代码:

代码语言:javascript
运行
复制
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;
            },

代码语言:javascript
运行
复制
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);
    }
};

请任何人帮助我解决这个问题。

EN

回答 1

Stack Overflow用户

发布于 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.

如果您正在寻找本地存储键值存储

代码语言:javascript
运行
复制
globalStorage['cache_1'].setItem("key",data);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20161703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档