Angular 2: No provider for (injected) service

后端 未结 2 824
太阳男子
太阳男子 2021-02-01 17:48

I have two services in my app - MainService and RightClickService. Only MainService is accessible globally in the application, and RightClickService is injected to MainService.

2条回答
  •  傲寒
    傲寒 (楼主)
    2021-02-01 18:20

    In addition to what already said, you must know two things:

    1. Your app has only one root injector that contains all providers delcared in @NgModule.providers array of any module in your app including AppModule.

    2. Each Component has its own injector (child injector of the root injector) that contains providers declared in @Component.providers array of the component.

    when angular want to resolve dependencies (RightClickService) of a service (MainService) it looks for it in the root injector which contains providers of all NgModules.

    When angular want to resolve dependencies (RightClickService) of a component (RightClickComponent) it looks for it in the component injector if not found it looks for it in the parent component injector if not found he will do the same until he reaches the root injector if not found an error will be thrown.

    if you want to solve the problem you can do this :

    function MainServiceFactory(RightClickService) {
        return new MainService(new RightClickService());
    }
    
    @NgModule({
      declarations: [
        AppComponent,
        ...
      ],
      imports: [
        BrowserModule,
        FormsModule,
        HttpModule
      ],
      providers: [
       {
         provide: MainService,
         useFactory: MainServiceFactory,
         deps: [RightClickService]
       }
    ],
      bootstrap: [AppComponent]
    })
    export class AppModule { }
    

提交回复
热议问题