NullInjectorError:AngularFirestoreのプロバイダーがありません


128

エラーを修正するための助けを探して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 'project-name' 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) {}
}

environemnt.ts:

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

その後、ngサーブ、そして私は上記のエラーを得ています...


角度7+でFireStore CRUD操作のために、この例をチェックしてくださいfreakyjolly.com/...
コードスパイ

回答:


241

追加する必要providers: [AngularFirestore]がありapp.module.tsます。

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

AngularFirestore:([object Object]、?)のすべてのパラメーターを解決できません。このエラーが再び発生する..
開発者


1
最後に、上記のリンクのおかげで動作しました。@ Sajeetharan
開発者

1
ドキュメンテーションが言うように、importingの代わりになぜそれをする必要があるのでしょうか?AngularFirestoreModuleこれはおそらくAngularFirestoreプロバイダーとして宣言することを含むすべてを処理します。

1
私にとってそれはすでにそこにありました、それを解決したのは単にCTRL+Cそれionic serveを再起動することでした...(Ionic 3以来、何らかの理由で頻繁に発生します..)
Ricky Levi

25

私は同じ問題を抱えていて、以下が解決されました。

古いサービスコード:

@Injectable()

更新された現用サービスコード:

@Injectable({
  providedIn: 'root'
})

「(TS)引数は0である必要がありますが、1を受け取りました。」というメッセージが表示されます。
Simon

1
新しいprovidedIn引数は、Angular 6以降でのみ使用できます。
James

9

開く:./src/app/app.module.ts
上部にFirebaseモジュールをインポートします。

'../environments/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
がんばってください


4

私にとって奇妙なことは、プロバイダーがあったことです:[]が、プロバイダーを使用するHTMLタグがエラーの原因でした。以下の赤いボックスを参照しています。 ここに画像の説明を入力してください

同じ「employee-list.component.ts」ファイル名の異なるコンポーネントに2つのクラスがあるため、プロジェクトは正常にコンパイルされましたが、参照がすべて混乱しています。


2

AngularFirestoreModule.enablePersistence()インポートセクションに追加すると問題が解決しました:

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

2

私はfirestoreを単にから削除することでこの問題を解決しました:

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

私のcomponent.tsファイルで。使用のみ:

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

これもあなたの問題です。


1

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操作のチュートリアルはこちらで確認してください

ここに画像の説明を入力してください


1

インポートを次から変更:

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

これへ:

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

これは私の問題を解決します。


0

私はそれを私の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


0

IonicアプリにFirebaseを追加するときにも同じ問題が発生しました。問題を解決するために、私はこれらのステップに従いました:

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]
})

以前は、SETTINGSの代わりにFirestoreSettingsTokenを使用していました。しかし、そのバグは解決されました。現在は設定を使用しています。(リンク

私のapp / services / myService.tsに次のようにインポートしました:

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

何らかの理由で、vscodeは「@ angular / fire / firestore / firestore」としてインポートしていました。I「@ angular / fire / firestore」に変更した後、問題は解決しました!

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.