如何在HTML5中实现app宽的内存缓存?

时间:2012-03-27 14:34:53

标签: javascript html5 caching singleton global-variables

有没有办法为HTML5 Web应用程序实现应用程序范围的内存缓存?

HTML5功能是否具有内存中的数据缓存?我不是在讨论仅存储服务器响应的浏览器缓存。我需要缓存更有效的对象。

我能想到的一种可能性是实现一个全局单例JavaScript对象,该对象将在应用程序的生命周期内创建一次,以便它可以处理缓存和检索数据。如果这是唯一的方法,那么如何创建这样的单例对象?

1 个答案:

答案 0 :(得分:5)

这是一个非常简单的单身人士,没有太多强制执行。它可以在一个真正受保护的方式上完成,其中Cache构造函数对于外部世界是不可访问的,请告诉我是否感兴趣。

function Cache() {
     if ("instance" in arguments.callee)
       throw "new instance is not desired";
    var simpleCache = {};

     this.set = function(key, data) {
        simpleCache[key] = data;
     };

     this.get = function(key) {
       return simpleCache[key];
     };  
};

Object.defineProperty(Cache, "instance", { value: new Cache(), writable: false });

现在按照您的期望打电话:

Cache.instance.set("key1", { a: "field1Value", b:12 });
Cache.instance.set("key2", new XMLHttpReuquest());