Angular 6静态注入器错误:Options没有提供程序。

10

我最近将我的项目从Angular5更新到了Angular6。项目已经成功构建,但是我在浏览器控制台中遇到了以下错误:

未处理的Promise拒绝:StaticInjectorError(AppModule)[options]: StaticInjectorError(平台:core)[options]: NullInjectorError:没有提供者选项!;区域:;任务:Promise.then; 值:错误:StaticInjectorError(AppModule)[options]

您有任何关于如何调试这些问题的想法吗?

这是我的app.module:

import { BrowserModule } from '@angular/platform-browser';
import { ServiceWorkerModule } from '@angular/service-worker';
import { environment } from '../environments/environment';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
import { RouterModule, Routes } from '@angular/router';
import { CookieModule } from 'ngx-cookie';
import { PushNotificationsModule, PushNotificationsService } from 'ng-push';

// importing notifications module (angular 2 notifications)
import { SimpleNotificationsModule, NotificationsService } from 'angular2-notifications';

import { NgIdleKeepaliveModule } from '@ng-idle/keepalive';

import { NgProgressModule } from '@ngx-progressbar/core';
import { NgProgressHttpClientModule } from '@ngx-progressbar/http-client';

import { GridModule } from './shared-modules/grid-module/grid.module';

// importing components
import { AppComponent } from './app.component';
import { LoginComponent } from './pages/login/login.component';
import { SampleRouteComponent } from './pages/sample-route/sample-route.component';

// services
import { GtmService } from './services/gtm/gtm.service';
import { AuthGuardService } from './services/auth-guard/auth-guard.service';
import { LoginService } from './services/login-service/login.service';
import { UserInfoService } from './services/user-info/user-info.service';
import { UtilityService } from './services/utility/utility.service';
import { IdleService } from './services/idle/idle.service';
import { GenericGridService } from './shared-modules/grid-module/generic-grid.service';
import { HttpInterceptorService } from './services/http-interceptor/http-interceptor.service';
import { ModalProviderService } from './services/modal-provider/modal-provider.service';
import { NotificationServiceService } from './services/notification-service.service';
import { Api } from './services/api';

const routes: Routes = [
  {
    path: 'login',
    component: LoginComponent
  },
  {
    path: 'sample-route',
    component: SampleRouteComponent
  },
  {
    path: '',
    loadChildren: './shared-modules/container/container.module#ContainerModule',
    canLoad: [AuthGuardService]
  }
];

@NgModule({
  declarations: [
    AppComponent,
    LoginComponent,
    SampleRouteComponent
  ],
  imports: [
    BrowserModule,
    ServiceWorkerModule.register('/ngsw-worker.js', { enabled: false }),
    BrowserAnimationsModule,
    FormsModule,
    HttpClientModule,
    GridModule,
    SimpleNotificationsModule,
    CookieModule.forRoot(),
    NgIdleKeepaliveModule.forRoot(),
    NgProgressModule.forRoot(),
    NgProgressHttpClientModule,
    RouterModule.forRoot(routes, { initialNavigation: 'enabled' }),
    PushNotificationsModule
  ],
  providers: [
    {
      provide: HTTP_INTERCEPTORS,
      useClass: HttpInterceptorService,
      multi: true
    },
    GtmService,
    LoginService,
    AuthGuardService,
    UserInfoService,
    UtilityService,
    IdleService,
    ModalProviderService,
    NotificationsService,
    GenericGridService,
    NotificationServiceService,
    Api,
    PushNotificationsService
  ],
  bootstrap: [AppComponent]
})
export class AppModule {

  private loginObserver;

  constructor(private loginService: LoginService, private utilityService: UtilityService, private idleService: IdleService,
    private userInfoService: UserInfoService) {
    this.loginService.checkLoggedIn();
    this.loginObserver = this.loginService.loginObserver.subscribe(
      loggedIn => {
        if (loggedIn) {
          const userdata: any = this.userInfoService.getUserInfo();
          this.utilityService.createNotification({
            title: 'Welcome!!',
            content: `${userdata.vchDiplayName}`
          });
          this.idleService.reset();
          this.loginObserver.unsubscribe();
        }
      }
    );
  }

}

您忘记导入一个必需的服务。请展示您的代码。 - Ulrich Dohou
"providers: [" 中的一项为空。这可能是一个模块导入问题 - 您可以使用 console.log 来确定是哪个问题...。" - Sam
你好,你解决了你的问题吗? - user7364588
@Alrick 暂时还没有。仍在努力。 - Subham Dey
5个回答

20

可能对提问者来说已经晚了,但我通过以下方式解决了此问题:

app.module.ts中将必要的服务添加到提供者列表中。

希望这能帮助未来遇到此问题的人。


1
但是想法是通过在Injectable中添加'providedIn'来避免这种情况,不是吗? - Ragul Parani

6

问题可能是您有一个非静态服务吗?如果您有一个非静态服务,您必须在使用它的组件中将其指定为提供程序。仅在app.modules.ts中将其指定为提供程序是不够的。

非静态服务

从服务中删除可注入指令(通常看起来像这样)。

@Injectable({
   providedIn: 'root'
})

在使用非静态服务的组件中,需要添加providers属性并指定服务。与常规服务一样,您还需要导入它。
import { EntryQueueHub } from 'app/services/hubs/entry-queue.hub';
@Component({
  selector: 'app-image-viewer',
  templateUrl: './image-viewer.component.html',
  styleUrls: ['./image-viewer.component.scss'],
  providers: [EntryQueueHub]
})
...
  constructor (
    private entryQueueHub: EntryQueueHub,
    ...

5

你可以尝试将SimpleNotificationsModule的导入方式更改为SimpleNotificationsModule.forRoot()。我也遇到了同样的错误,通过这种方式进行更改后问题得以解决。


3
在app.module的providers中添加服务可以解决这个问题。

1

缺少一些带有静态方法的模块来配置提供者也可能导致同样的问题。

例如,考虑RouterTestingModule,它有一个名为withRoutes()的静态方法来配置提供者。

从Angular编译器和注入器的角度来看,这可以被视为注入器中缺少的令牌。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接