首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >javascript -解压缩json,将缓冲区转换为字符串

javascript -解压缩json,将缓冲区转换为字符串
EN

Stack Overflow用户
提问于 2018-10-21 03:17:36
回答 1查看 1.1K关注 0票数 0

我正在使用JSZipUtils解压一个json文件:

代码语言:javascript
复制
<head>
    <meta charset="UTF-8">
    <script src="node_modules/jszip/dist/jszip.min.js"></script>
    <script src="node_modules/file-saver/dist/FileSaver.min.js"></script>
    <script src="node_modules/jszip-utils/dist/jszip-utils.min.js"></script>    
</head>

<script>
JSZipUtils.getBinaryContent('data/top8.json.zip', function(err, data) {
    if(err) {
        throw err; // or handle err
    }

    JSZip.loadAsync(data).then(function () {
        console.log(data);
    });
});
</script>

我得到的响应如下:

期望的响应:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-21 09:41:10

这就是最终有效的方法:

代码语言:javascript
复制
<head>
    <script src="lzwCompress.js"></script>
</head>

<script>
var lzwCompress = window.lzwCompress;
json_path = "data/top8.json";

function compress() {
    xttp = new XMLHttpRequest();
    xttp.open("GET", json_path);
    xttp.send();
    xttp.onreadystatechange= function() {
        if(this.readyState == 4 && this.status == 200){
            var data = JSON.parse(this.responseText);
            var compressed = lzwCompress.pack(data);
            var compressed = JSON.stringify(compressed)
            download(compressed, 'top8_compressed.json', 'utf8');
        }
    }
}

function decompress() {
    xttp = new XMLHttpRequest();
    xttp.open("GET", "data/top8_compressed.json");
    xttp.send();
    xttp.onreadystatechange= function() {
        if(this.readyState == 4 && this.status == 200){
            var data = JSON.parse(this.responseText);
            var original = lzwCompress.unpack(data);
            console.log(original);
        }
    }
}

function download(content, fileName, contentType) {
    var a = document.createElement("a");
    var file = new Blob([content], {type: contentType});
    a.href = URL.createObjectURL(file);
    a.download = fileName;
    a.click();
}

compress();
decompress();
</script>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52909290

复制
相关文章

相似问题

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