【发布时间】:2017-08-29 10:23:24
【问题描述】:
我已经编写了以下代码,用于在 Promise 的帮助下异步上传服务器上的文件。我们知道,一旦任何一个 Promise 失败,promise.all 就会失败。所以,我想知道哪个承诺实际上失败了,在我的情况下,承诺失败的文件名。我正在尝试 console.log(e1) 但它没有给我有关失败承诺的信息。任何人都可以帮我做吗?
uploadFilesAndSendStatus(stateType, notes, estimate, visibleToCustomer = null)
{
let filesPromise = Promise.resolve([]);
const promises = this.state.files_to_upload.map((file) => {
return this.uploadFilesOnServer(file);
});
filesPromise = Promise.all(promises).then((results) => {
return [].concat(...results);
}).catch((e1) =>{
console.log(e1);
this.setState({
serverActionPending: false,
serverActionComplete: false,
file_upload_try_again: true,
});
});
}
UploadFilesOnServer 代码为:
uploadFilesOnServer(file) {
let files=[];
let file_id='';
const image=file;
const promise = getAttachmentUploadURL(this.props.task.id)
.then((imageUrlResponse) => {
const data = new FormData();
data.append('file-0', image);
const { upload_url } = JSON.parse(imageUrlResponse);
return uploadAttachment(upload_url, data);
})
.then ((updateImageResponse) => {
file_id= JSON.parse(updateImageResponse);
files.push(file_id);
return files;
});
return promise;
}
【问题讨论】:
-
这可能是一个解决方案:bluebirdjs.com/docs/api/reflect.html
-
我认为你不想
JSON.parsee1 -
是的。已编辑。 @Bergi 但我仍然无法获得所需的信息。
标签: javascript reactjs ecmascript-6 es6-promise