【发布时间】:2017-04-04 03:14:34
【问题描述】:
我想多次触发 promise 函数,直到服务器返回适当的请求状态。我将此函数称为“checkStatus”。我不知道如何实现这一点。
saveFile() {
this.createMetadataContainer(this.fileId).then((data) => {
this.metadataInfo = data;
return this.createResourceMember(data, this.fileId, this.code);
}).then((data) => {
this.metadataInfo = data;
return this.applyCodeChanges(data);
}).then((data) => {
return this.checkStatus(data.id, this.metadataInfo);
}).catch((err) => {
this.deleteMetadataContainer(this.metadataInfo);
}).then((data) => {
this.msg = 'Code Saved';
});
}
这就是我编写 checkStatus 函数的方式:
checkStatus(id, metadataInfo) {
let promise = this.server.retrieve('ContainerAsyncRequest', id).then((data) => {
if(data.State == "Completed") {
return data;
}else if(data.State == "Queued") {
this.msg = 'Saving Code...';
return setTimeout(this.checkStatus(id, metadataInfo), 2000);
}else {
this.msg = 'Compiler Error ' + data.CompilerErrors;
return data;
}
});
return promise;
}
【问题讨论】:
标签: angular typescript promise