将压缩的json数据存储在本地存储中

Raj*_*eev 18 javascript compression html5 json local-storage

我想将JSON数据存储在本地存储中.有时存储的数据可能超过5MB(浏览器允许每个域的最大阈值).无论如何我可以压缩或压缩数据并将其存储在本地存储中吗?如果对大数据上的每个JS函数进行压缩和解压缩,它会增加多少延迟?

我正在使用这个json数据在网页上显示.....它就像一个静态数据,对于整个会话来说大致相同.我们在这个json数据上提供搜索,过滤等操作...每当用户输入关键字时,我会搜索存储在本地存储中的这个json数据,而不是调用服务器

Rau*_*ria 14

由于localStorage功能似乎仅限于处理字符串键/值对,您可以做的是使用lz-string库对json对象进行字符串化并压缩它,然后将其存储在localStorage中

用法

// sample json object
var jsonobj = {'sample': 'This is supposed to be ling string', 'score': 'another long string which is going to be compressed'}

// compress string before storing in localStorage    
localStorage.setItem('mystring', LZString.compress(JSON.stringify(jsonobj)));

// decompress localStorage item stored
var string = LZString.decompress(localStorage.getItem('mystring'))

// parse it to JSON object
JSON.parse(string);
Run Code Online (Sandbox Code Playgroud)

检查jsfiddle http://jsfiddle.net/raunakkathuria/7PQtC/1/,因为我复制了完整的脚本,所以在小提琴的末尾寻找运行代码

  • 它在lz-string网站上说`compress`产生无效的UTF16字符串,只能在webkit浏览器上运行.`compressToUTF16`和`compressFromUTF16`应该用于跨浏览器兼容性. (7认同)