【发布时间】:2019-02-26 12:34:24
【问题描述】:
在我的项目中,我面临一个挑战。即..我需要一个一个调用多个API调用。在这里,我使用 RxJS flatMap 运算符。它按预期工作。但我的额外要求是我需要为每个 API 调用设置 10 秒的延迟。我使用了“节流”运算符,但它不起作用。我在下面附上了我的代码。谁能告诉我们我的代码做错了什么。
public makeSubmitAPI(oncallData): Observable<any> {
let orderPayload = this.postAPIService.prepareOrderPayload(oncallData);
let url = "";
let orderResponse: any;
return this.apiCallsService.apiCall('placeOrder', orderPayload, 'post', false)
.map((orderRes: any) => {
orderResponse = orderRes;
url = `orders/${orderResponse.data.id}/progress`;
let progressPayload = this.postAPIService.prepareProgressAPIData(oncallData, orderResponse.data, this.userType);
return progressPayload;
}).pipe(throttle(val=> interval(5000)))
.flatMap(progressPayload => {
return this.apiCallsService.apiCall(url, progressPayload, 'post', false).pipe(throttle(val=> interval(5000)))
})
.flatMap(progressResponse => {
return Observable.combineLatest(
orderResponse.data.serviceAddresses.map((address, index) => {
let fullfilledAPI = this.postAPIService.prepareFullfilledAPIData(oncallData, orderResponse.data, progressResponse, this.userType, index, orderPayload);
return this.apiCallsService.apiCall('fullfillment', fullfilledAPI, 'post', false).map(res => res);
})
)
});
}
谢谢
【问题讨论】:
标签: javascript angular typescript rxjs