我有一个情况。我有一个for循环。我正在将每个对象信息发送给服务,并从服务中获取响应。
我想暂停for循环,并在http客户端返回响应后继续。这是我的服务代码:
for (var j = 0, counter = 0; j < this.actualObj.length; j++) {
this._custService.placingSingleOrder(this.actualObj[j], this.headerInfo).subscribe(
(data) => {
console.log(data);
counter++;
if (data.status == "success") {
this.sucessOrders.push(data.inserted_order_id);
console.log('order inserted success fully........');
// this.toastr.success('Order Submitted Succefully !', 'Success!');
} else if (data.status == "failure") {
// this.toastr.error('Order is already present in the database. Please check and try again!', 'Oopssssss!');
}
if (counter == this.actualObj.length) {
this.updateStatus();
}
},
(error) => {
counter++
if (counter == this.actualObj.length) {
this.updateStatus();
}
// this.loader = false;
console.log(error);
}
);
}
placingSingleOrder(obj, headerInfo) {
let api_token = sessionStorage.getItem('api_token');
let email = sessionStorage.getItem('email');
console.log('before calling serviccccce', headerInfo);
this.singleOrderHeader = {
headers: new HttpHeaders({
'Content-Type': 'text/plain',
'apitoken': headerInfo.apitoken,
//'apitoken': 'fkjdhsfhbdsabf',
'customer_id': headerInfo.customer_id,
'order_id': headerInfo.order_id
})
};
console.log('before calling serviccccce', this.singleOrderHeader);
return this.http.post(apiServicesURL + 'api/restapi/Order/addMwwOrder', JSON.stringify({ token: api_token, email: email, Order: obj }), this.singleOrderHeader).map((response: any) => {
console.log("single order response is: ", response);
return response;
});
}
因此,一旦第一个迭代给出响应,则第二个迭代应该开始。举例说明我。
答案 0 :(得分:1)
尝试使用递归函数而不是循环调用,每次成功后观察,然后再次调用函数,设置一个基本情况(即递归调用,除非并且直到循环结束为止)
尝试一下:
const j = this.actualObj.length; // set it global
recursiveFunction(this.j) {
this._custService
.placingSingleOrder(this.actualObj[this.j], this.headerInfo)
.subscribe(data => {
// your code handler after each success
this.j--; // decrease operator and call recursive function
if(this.j) {
this.recursiveFunction(this.j);
}
}, error => {
// error handler
})
}