javascript - Angular 2 错误处理 - 发送到订阅的组件

标签 javascript angular error-handling rxjs

我正在使用 Angular 2 HTTP,并且有一个订阅响应的组件。但是,当出现错误时,catch 方法不会将错误返回给订阅的组件。它只是将它扔到控制台中。

 saveFinalize(fcData: LastForecastInterface) {
    let responseData = JSON.stringify(fcData);
    let body = responseData;

    const headers = new Headers();
    headers.append('Content-Type', 'application/json;charset=UTF-8');

    return this.http.post('/saveFinalize', body, { headers: headers })
      .map((data: Response) => data.json())
      .catch(this.handleError);
}

public handleError(error: Response | any) {
    console.log('err: ', error)
    let errMsg: string;
    if (error instanceof Response) {
        const body = error.json() || '';
        const err = body.error || JSON.stringify(body);
        errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
        errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    // return Observable.throw(errMsg);
    return errMsg;
}

我订阅的组件没有得到响应

saveFinalize() {
  this.loadingData = true;
  return this.httpService.saveFinalize(this.getFc.fcData)
    .subscribe(response => {
        this.loadingData = false;
        console.log(response);
        let saveResponse = response.success ? 'Successfully Saved Finalized!' : 'Error Saving Finalized! - ' + response.message;
        let respType = response.success ? 'success' : 'danger';
        this.alertSvc.showAlert(saveResponse, respType);
    });
}

最佳答案

在此处查看此代码:(来自 https://angular.io/docs/ts/latest/guide/server-communication.html)

getHeroes() {
  this.heroService.getHeroes()
                  .subscribe(
                    heroes => this.heroes = heroes,
                    error =>  this.errorMessage = <any>error);
}

注意 .subscribe() 方法有 2 个参数。一个是您使用的响应,下一个是错误。为了将错误传递给订阅的组件,您必须使用后面的参数,这将使您的代码看起来像这样:

  return this.httpService.saveFinalize(this.getFc.fcData).subscribe(response => {
    this.loadingData = false;
    console.log(response);
    let saveResponse = response.success ? 'Successfully Saved Finalized!' : 'Error Saving Finalized! - ' + response.message;
    let respType = response.success ? 'success' : 'danger';
    this.alertSvc.showAlert(saveResponse, respType);
  }, error => {
    // the errorMessage will be passed here in this "error" variable
  });

当订阅的方法返回一个成功的响应时,你只会得到你的响应。但是当订阅的方法抛出错误时,您不会得到响应,您只会得到错误(这是 subscribe() 方法的第二个参数)。

您还需要从 handleError() 方法中抛出错误。因此,您不应仅返回字符串值 (return errMsg;),而应使用 return Observable.throw(errMsg);

关于javascript - Angular 2 错误处理 - 发送到订阅的组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42677267/

相关文章:

javascript - 在哪里可以获得 javascript 国家世界地图的形状文件?

JavaScript 文件随机损坏?

ruby-on-rails - JSON对象在 Controller 中丢失其值

Javascript 我正在尝试制作一个井字游戏,如果这个人对 Angular 线获胜,它就不起作用

javascript - 使用相同的函数创建多个对象

angular - Azure存储javascript客户端: how to track upload progress using Ionic/Angular?

rest - Spring REST异常-获取响应有效负载

swift - “ fatal error :在展开可选值时意外发现nil”是什么意思?

angular - 通过 Angular 2 中的输入装饰器使用多个属性

javascript - Angular 2 ngFor 中不同组件的列表