【问题标题】:NullInjectorError: No provider for AngularFirestoreNullInjectorError:没有 AngularFirestore 的提供者
【发布时间】:2018-05-02 23:27:07
【问题描述】:

我正在学习 Angular 以寻求解决错误的帮助: 我正在关注这个链接:https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md 用 angular2 和 angularfirestore2 创建一个有角度的小应用程序

但是当我点击 ng serve 时,我在浏览器控制台中收到以下错误..

StaticInjectorError[AngularFirestore]: 
  StaticInjectorError[AngularFirestore]: 
    NullInjectorError: No provider for AngularFirestore!
    at _NullInjector.get (core.js:923)
    at resolveToken (core.js:1211)
    at tryResolveToken (core.js:1153)
    at StaticInjector.get (core.js:1024)
    at resolveToken (core.js:1211)
    at tryResolveToken (core.js:1153)
    at StaticInjector.get (core.js:1024)
    at resolveNgModuleDep (core.js:10585)
    at NgModuleRef_.get (core.js:11806)
    at resolveDep (core.js:12302)

我尝试用谷歌搜索它,但没有找到确切的解决方案,对我没有任何效果:(,

这是我遵循的: 1) 安装节点版本 8.9.1 2) npm install -g @angular/cli --> 版本 1.5.2 3) ng new '项目名称' 4) npm install angularfire2 firebase --save

这是我的 app.module.ts 文件:

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { AngularFireModule } from 'angularfire2';
import { environment } from '../environments/environment';

@NgModule({
  imports: [
    BrowserModule,
    AngularFireModule.initializeApp(environment.firebase)
  ],
  declarations: [ AppComponent ],
  bootstrap: [ AppComponent ]
})
export class AppModule {}

app.component.ts:

import { Component } from '@angular/core';
import { AngularFirestore } from 'angularfire2/firestore';
import { Observable } from 'rxjs/Observable';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'app';
  constructor(db: AngularFirestore) {}
}

环境.ts:

export const environment = {
  production: false,
  firebase: {
    apiKey: 'xxxxx',
    authDomain: 'aaaaaaa',
    databaseURL: 'bbbbbbbbbbbbbbbbbb',
    projectId: 'aaaaaaaaaaaaaa',
    storageBucket: 'aaaaaaaaaaaa',
    messagingSenderId: 'aaaaaaaaaaaaa'
  }
};

然后 ng 服务,我收到上述错误...

【问题讨论】:

    标签: angular firebase google-cloud-firestore angularfire2


    【解决方案1】:

    您应该在 app.module.ts 中添加 providers: [AngularFirestore]

    @NgModule({
      imports: [
        BrowserModule,
        AngularFireModule.initializeApp(environment.firebase)
      ],
      declarations: [ AppComponent ],
      providers: [AngularFirestore],
      bootstrap: [ AppComponent ]
    })
    export class AppModule {}
    

    【讨论】:

    • 无法解析 AngularFirestore 的所有参数:([object Object], ?)。又是这个错误..
    • 终于可以使用上面的链接感谢@Sajeetharan
    • 为什么我需要这样做,而不是像文档中所说的 importing AngularFirestoreModule,它可能会处理所有事情,包括将 AngularFirestore 声明为提供者。
    • 对我来说它已经存在了,解决它的只是 CTRL+C ionic serve 并重新启动它......(自从 Ionic 3 以来,由于某种原因经常发生......)
    【解决方案2】:

    打开:./src/app/app.module.ts
    并在顶部导入 Firebase 模块:

    从 '../environments/environment' 导入 { environment };
    从 'angularfire2' 导入 { AngularFireModule };
    从 'angularfire2/firestore' 导入 { AngularFirestoreModule };

    非常重要:
    记得更新 NgModule 中的“导入”:

    @NgModule({
      declarations: [
        AppComponent,
        OtherComponent // Add other components here
        ...
      ],
      imports: [
        BrowserModule,
        AngularFireModule.initializeApp(environment.firebase, 'your-APP-name-here'),
        AngularFirestoreModule
      ],
      ...
    })
    

    试一试,它现在应该可以工作了。
    有关详细信息,请参阅 angularfire2 文档:
    https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
    祝你好运!

    【讨论】:

      【解决方案3】:

      对我来说奇怪的是我有 provider:[],但使用提供程序的 HTML 标记是导致错误的原因。我指的是下面的红框:

      事实证明,我在不同的组件中有两个类,具有相同的“employee-list.component.ts”文件名,因此项目编译良好,但引用都搞砸了。

      【讨论】:

        【解决方案4】:

        在导入部分添加AngularFirestoreModule.enablePersistence() 解决了我的问题:

        imports: [
            BrowserModule, AngularFireModule, 
            AngularFireModule.initializeApp(config),
            AngularFirestoreModule.enablePersistence()
        ]
        

        【讨论】:

          【解决方案5】:

          我遇到了同样的问题,下面已经解决了。

          旧服务代码:

          @Injectable()
          

          更新的工作服务代码:

          @Injectable({
            providedIn: 'root'
          })
          

          【讨论】:

          • 向我显示以下消息:“(TS) 预期 0 个参数,但得到 1 个。”
          • 新的 providedIn 参数仅在 Angular 6 及更高版本中可用。
          • 如果可能值得注意此更改的作用。在不添加providedIn: 'root' 的情况下,我们将类记录为可注入的。添加providedIn: 'root' 使这个类可以在应用程序的任何地方注入,从root 开始。
          【解决方案6】:

          我把它带到我的 app.module 中。导入后它应该可以工作

          providers: [
              { provide: LocationStrategy, useClass: HashLocationStrategy },
              { provide: FirestoreSettingsToken, useValue: {} }
            ],
          

          我的版本:

          Angular CLI: 7.2.4
          Node: 10.15.0
          Angular: 7.2.5
          ... common, compiler, compiler-cli, core, forms
          ... language-service, platform-browser, platform-browser-dynamic
          ... router
          
          Package                           Version
          -----------------------------------------------------------
          @angular-devkit/architect         0.12.4
          @angular-devkit/build-angular     0.12.4
          @angular-devkit/build-optimizer   0.12.4
          @angular-devkit/build-webpack     0.12.4
          @angular-devkit/core              7.2.4
          @angular-devkit/schematics        7.2.4
          @angular/animations               8.0.0-beta.4+7.sha-3c7ce82
          @angular/cdk                      7.3.2-3ae6eb2
          @angular/cli                      7.2.4
          @angular/fire                     5.1.1
          @angular/flex-layout              7.0.0-beta.23
          @angular/material                 7.3.2-3ae6eb2
          @ngtools/webpack                  7.2.4
          @schematics/angular               7.2.4
          @schematics/update                0.12.4
          rxjs                              6.3.3
          typescript                        3.2.4
          webpack                           4.28.4
          
          

          【讨论】:

            【解决方案7】:

            对于AngularFire2最新版本

            安装AngularFire2

            $ npm install --save firebase @angular/fire
            

            然后更新app.module.ts文件

                import { BrowserModule } from '@angular/platform-browser';
                import { NgModule } from '@angular/core';
            
                import { AppComponent } from './app.component';
                import { FormsModule } from '@angular/forms';
            
            
                import { AngularFireModule } from '@angular/fire';
                import { AngularFireDatabaseModule } from '@angular/fire/database';
                import { environment } from '../environments/environment';
                import { AngularFirestoreModule } from '@angular/fire/firestore';
            
            
                @NgModule({
                  declarations: [
                    AppComponent
                  ],
                  imports: [
                    BrowserModule,
                    FormsModule,
            
                    AngularFireModule.initializeApp(environment.firebase),
                    AngularFirestoreModule,
                    AngularFireDatabaseModule
                  ],
                  providers: [],
                  bootstrap: [AppComponent]
                })
                export class AppModule { }
            

            查看FireStore CRUD操作教程here

            【讨论】:

              【解决方案8】:

              我通过从以下位置删除 firestore 解决了这个问题:

              import { AngularFirestore } from '@angular/fire/firestore/firestore';
              

              在我的 component.ts 文件中。 仅供参考:

              import { AngularFirestore } from '@angular/fire/firestore';
              

              这也可能是您的问题。

              【讨论】:

                【解决方案9】:
                import angularFirebaseStore 
                

                app.module.ts 中并将其设置为类似服务的提供者

                【讨论】:

                  【解决方案10】:

                  更改您的导入来源:

                  import { AngularFirestore } from '@angular/fire/firestore/firestore';
                  

                  到这里:

                  import { AngularFirestore } from '@angular/fire/firestore';
                  

                  这解决了我的问题。

                  【讨论】:

                    【解决方案11】:

                    我在将 firebase 添加到我的 Ionic 应用时遇到了同样的问题。为了解决这个问题,我按照以下步骤操作:

                    npm install @angular/fire firebase --save
                    

                    在我的 app/app.module.ts 中:

                    ...
                    import { AngularFireModule } from '@angular/fire';
                    import { environment } from '../environments/environment';
                    import { AngularFirestoreModule, SETTINGS } from '@angular/fire/firestore';
                    
                    @NgModule({
                      declarations: [AppComponent],
                      entryComponents: [],
                      imports: [
                        BrowserModule, 
                        AppRoutingModule,
                        AngularFireModule.initializeApp(environment.firebase),
                        AngularFirestoreModule
                      ],
                      providers: [
                        { provide: SETTINGS, useValue: {} }
                      ],
                      bootstrap: [AppComponent]
                    })
                    

                    之前我们使用 FirestoreSettingsToken 而不是 SETTINGS。但是那个错误得到了解决,现在我们使用设置。 (link)

                    在我的 app/services/myService.ts 我导入为:

                    import { AngularFirestore } from "@angular/fire/firestore";
                    

                    出于某种原因,vscode 将其导入为“@angular/fire/firestore/firestore”;我 将其更改为“@angular/fire/firestore”后;问题解决了!

                    【讨论】:

                      【解决方案12】:

                      简单的答案。

                      无论何时遇到NullInjector error。 原因总是import/providersmissing

                      解决方案:

                      1. 请在module.ts 文件中的imports 数组中添加模块。

                      2. modules.ts 文件中的providers 数组中添加您要使用的服务。

                      @NgModule({})
                      export class SomeModule{
                       `imports:[]`,
                      `providers: []`
                      }
                      

                      【讨论】:

                      • 简单的答案是正确的,但解决方案是错误的。这将使您的代码快速无法维护
                      猜你喜欢
                      • 2018-08-11
                      • 2019-11-16
                      • 2021-01-20
                      • 2019-06-25
                      • 2018-09-19
                      • 2020-12-25
                      • 1970-01-01
                      • 1970-01-01
                      • 1970-01-01
                      相关资源
                      最近更新 更多