var bl = window.URL.createObjectURL(xhr.response)
var zip = new JSZip();
zip.file(bl);
zip.generateAsync({type:"blob"})
.then(function(content) {
saveAs(content, "example.zip");
}, function(err){
console.log(err)
})
我的 XmlHttpRequest 从图像文件中获取了“blob”类型的响应。如何将 blob 图像文件转换为图像文件(可以是 .gif、.jpg、.bmp、.jpg-large 等),以便制作没有错误的 zip 文件?
使用
URL.createObjectURL
,您可以获得 blob 的 url(例如 blob:https://stackoverflow.com/e62c177a-b4b1-4945-8e13-53bb5a3c8f34
)。 JSZip 无法解决该问题,但您可以直接使用该 blob(因此在您的情况下为 xhr.response
)。正如帕特里克·埃文斯(Patrick Evans)在评论中所说,您还需要提供文件名。
var zip = new JSZip();
zip.file("my_file.ext", xhr.response);
zip.generateAsync({type:"blob"})
.then(function(content) {
saveAs(content, "example.zip");
}, function(err){
console.log(err)
});
JSZip v3 支持 blob 作为文件内容。
Usage:
zip.file("image.png", blob);