7

我在我的应用程序中使用子组件的延迟加载策略。在应用程序的顶层,我有拦截所有 ajax 调用的自定义 HTTP 提供程序。

    providers:[{
        provide: Http,
        useFactory: (backend: XHRBackend, defaultOptions: RequestOptions, cookieService: CookieService) => new CustomHttp(backend, defaultOptions, cookieService),
        deps: [XHRBackend, RequestOptions, CookieService]
    }]

我的延迟加载模块不会影响此自定义提供程序。有没有办法也为他们提供?providers在 component.module 文件中的属性中没有重复代码。谢谢!

4

1 回答 1

3

我已经用@SkipSelf()修复了它。每个延迟加载的模块都有自己的注入器,因此它对应用程序级别内的扩展 Http 提供程序一无所知。当您在服务中(在延迟加载的模块中)注入 Http 提供程序时,Angular 正试图在模块的注入器中找到 Http 提供程序......并从“@angular/http”中找到原始提供程序。但是您需要找到在应用程序级别内“可见”的扩展 Http 提供程序。因此,请尝试在构造函数中的 Http 之前添加 @SkipSelf() :

import { SkipSelf } from '@angular/core';

constructor(@SkipSelf() private http: Http) {
}
于 2017-07-09T20:59:13.873 回答