最佳答案
如何将多个独立的 HTTP 拦截器添加到 Angular 4应用程序中?
我试图通过使用多个拦截器扩展 providers
数组来添加它们。但是只有最后一个被实际执行,Interceptor1
被忽略。
@NgModule({
declarations: [ /* ... */ ],
imports: [ /* ... */ HttpModule ],
providers: [
{
provide: Http,
useFactory: (xhrBackend: XHRBackend, requestOptions: RequestOptions) =>
new Interceptor1(xhrBackend, requestOptions),
deps: [XHRBackend, RequestOptions],
},
{
provide: Http,
useFactory: (xhrBackend: XHRBackend, requestOptions: RequestOptions) =>
new Interceptor2(xhrBackend, requestOptions),
deps: [XHRBackend, RequestOptions]
},
],
bootstrap: [AppComponent]
})
export class AppModule {}
显然,我可以将它们组合成一个单独的 Interceptor
类,这应该是可行的。但是,我希望避免这种情况,因为这些拦截器有完全不同的用途(一个用于错误处理,一个用于显示加载指示器)。
那么如何添加多个拦截器呢?