gpt4 book ai didi

javascript - 如何在 react.js 中实现 jszip

转载 作者:行者123 更新时间:2023-12-03 23:53:54 25 4
gpt4 key购买 nike

我正在尝试在通过 http 请求发送之前压缩文件列表。但我被困在这里。

export default function zipTargetFiles(files) {
if (files.length <= 1) {
return files;
} else {
const zip = require('jszip')();
for (let i = 0; i < files.length; i++) {
zip.file(files[i].name, files[i]);
}
return zip.generateAsync({type:"blob"});
}

}

基本上,该函数接收文件列表并尝试将它们压缩到一个 .zip 文件中。但是当我将它作为形成的数据发送出去时,它给出了提交的数据不是文件的错误。

我检查了 header 中的有效负载,目标字段为 [object Promise] .如何真正返回 .zip 文件?

现在我可以在 Redux-saga 中捕获 zip 文件,但是当我将它保存在我的数据库中时它没有给出扩展名,而是它只给出了“blob”的名称。

传奇.js
const file = yield call(zipTargetFiles, files);
const formData = new FormData();
formData.append("coversheet", file);
const reponse = yield call(apiRequest, formData);

最佳答案

发生的事情是 .generateAsync正在返回一个 promise 。您必须等到 promise 被履行或被拒绝后才能使用数据。

Promises 是 JS 中处理异步操作时的核心概念。您可以阅读有关 promise 的更多信息 here

import zipTargetFiles from '/path'

zipTargetFiles( data ).then(file => {
// Access your file here
})

关于javascript - 如何在 react.js 中实现 jszip,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52882703/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com