在Angular 2中使用Observable进行错误处理

前端之家收集整理的这篇文章主要介绍了在Angular 2中使用Observable进行错误处理前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图将HTTP请求中可能发生的任何错误传递给我所有服务的公共日志记录服务:

import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/catch';

constructor(logger: LoggerService) { }

doSomething(): Observable<any> {
    return this.http
        .post('/foo/bar',{})
        .catch(this.notifyErrors);
}

protected notifyErrors(error: any): Observable<any> {
    this.logger.log(error);

    return Observable.throw(error);
}

不幸的是,在notifyErrors方法中,这会丢失.我已经尝试将其定义为胖箭头,但我从TS编译器中获取了类型错误.我已经使用了Observable文档中的确切语法.

解决方法

如果传递函数引用,则需要修复此问题

.catch(this.notifyErrors.bind(this));

或者

.catch(() => this.notifyErrors());

另见https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions

猜你在找的Angularjs相关文章