当我们得到响应时,Angular 5继续迭代

时间:2018-07-10 10:08:32

标签: async-await angular5 httpclient delay

我有一个情况。我有一个for循环。我正在将每个对象信息发送给服务,并从服务中获取响应。

我想暂停for循环,并在http客户端返回响应后继续。这是我的服务代码:

.ts文件

 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;

    });

}

因此,一旦第一个迭代给出响应,则第二个迭代应该开始。举例说明我。

1 个答案:

答案 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
  })
}