首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角7-注入服务总是空的。

角7-注入服务总是空的。
EN

Stack Overflow用户
提问于 2020-03-09 20:12:44
回答 1查看 734关注 0票数 2

我有一个7角的应用程序。我创建了一个实现HttpInterceptor的服务。这是代码,减去导入

代码语言:javascript
复制
@Injectable({
  providedIn: 'root'
})
export class InterceptorService implements HttpInterceptor {

  constructor(private errorLoggingService:ErrorLoggingService) {

  }

  handleError(error: HttpErrorResponse) {    
    this.errorLoggingService.logErrorData(error);
    return throwError(error);
  }

  //configure the interceptor
  intercept(req: HttpRequest<any>, next: HttpHandler):Observable<HttpEvent<any>> {
    return next.handle(req)
      .pipe(
        catchError(this.handleError)
      )
  };
}

这里的目的是捕获Http错误(来自调用后端服务)并将它们记录到errorLoggingService实例中。类ErrorLoggingService的定义如下:

代码语言:javascript
复制
@Injectable({
    providedIn: 'root'
})
export class ErrorLoggingService {

    constructor(private httpClient:HttpClient) {

    }

    //logs the error to the nodeJS endpoint
    public logErrorString(error:string)
    {

    }

    public logErrorData(error:any) {

    }

}

我的问题是,在handleError()函数中,this.errorLoggingService是未定义的,因为'this‘指的是可观测的(我认为),因为在拦截方法中,可观测到的数据是管道化的。

在这里,我如何实际引用类变量或类范围内的任何内容?或者,如何将errorLoggingService传递给handleError方法?那也没关系。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-03-09 20:35:18

它是undefined,因为当您传递函数的引用时,context就丢失了。它的context停止引用InterceptorService实例。

您需要显式绑定context

代码语言:javascript
复制
catchError(this.handleError.bind(this))

或者用箭头函数调用它,保存它。

代码语言:javascript
复制
catchError(err => this.handleError(err))
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60607703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档