NullInjectorError: AngularFirestore için sağlayıcı yok


131

Ben Açısal hatasının düzeltilmesi yardım arayan öğreniyorum: Ben bu bağlantıyı takip ediyorum https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md bir açısal küçük oluşturun angular2 ve angularfirestore2 ile uygulama

ancak hizmete bastığımda tarayıcı konsolunda aşağıdaki hatayı alıyorum ..

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)

Googling'i denedim ama benim için hiçbir şey işe yaramayan kesin çözümü bulamadım :(,

İşte takip ettiğim şey: 1) Yüklü Düğüm Sürümü 8.9.1 2) npm install -g @ angular / cli -> Sürüm 1.5.2 3) ng yeni 'proje-adı' 4) npm angularfire2 firebase'i kurun - kaydet

İşte app.module.ts dosyam:

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'
  }
};

daha sonra servis atıyor ve yukarıdaki hatayı alıyorum ...


Yanıtlar:


243

Sen eklemek gerekir providers: [AngularFirestore]yılında app.module.ts.

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

AngularFirestore için tüm parametreler çözülemiyor: ([nesne Nesnesi],?). bu hata tekrar ..
Geliştirici


1
nihayet yukarıdaki bağlantıyla çalıştı teşekkürler @Sajeetharan
Geliştirici

1
Neden yerine, bunu yapmak gerekir importing AngularFirestoreModulebelgeleri tahminen ilan dahil her şeyi halleder, hangi söylediği gibi, AngularFirestorebir sağlayıcı olarak.

1
orada zaten benim için ne basitçe çözüldü (hiç İon 3'ten beri nedense sık sık olur ..) ... ve onu yeniden başlatmasınıCTRL+Cionic serve
Ricky Levi

26

Aynı sorunu yaşadım ve aşağıda çözüldü.

Eski Servis Kodu:

@Injectable()

Güncellenmiş çalışan Servis Kodu:

@Injectable({
  providedIn: 'root'
})

bana şu mesajı gösteriyor: "(TS) 0 argüman bekleniyor, ancak 1 var."
Simon

1
Yeni providedInargüman yalnızca Angular 6 ve üzeri sürümlerde mevcuttur.
James

9

Aç: ./src/app/app.module.ts
Ve en üstte Firebase Modüllerini içe aktar:

{ environment } öğesini "../environment/environment" içinden içe aktar; 'angularfire2'den
{ AngularFireModule } dosyasını içe aktarın ; 'angularfire2 / firestore'dan
{ AngularFirestoreModule } içe aktarın ;

Ve ÇOK ÖNEMLİ:
NgModule'da 'içe aktarmaları' güncellemeyi unutmayın:

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

Bir deneyin, şimdi çalışacaktır.
Ayrıntılı bilgi için angularfire2 belgelerini takip edin :
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
İyi şanslar!


4

Benim için garip olan şey, sağlayıcıya sahip olmamdı: [], ancak sağlayıcıyı kullanan HTML etiketi hataya neden olan şeydi. Aşağıdaki kırmızı kutuya atıfta bulunuyorum: görüntü açıklamasını buraya girin

Görünüşe göre, farklı bileşenlerde aynı "staff-list.component.ts" dosya adına sahip iki sınıfım vardı ve bu yüzden proje iyi derlendi, ancak referansların hepsi karışıktı.


2

AngularFirestoreModule.enablePersistence()İçe aktarma bölümüne eklemek sorunumu çözdü:

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

2

Bu sorunu sadece firestore'u şuradan kaldırarak çözdüm :

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

component.ts dosyamda. sadece kullanım olarak:

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

bu aynı zamanda senin sorunun olabilir.


1

İçin AngularFire2 Son sürümü

AngularFire2'yi yükleyin

$ npm install --save firebase @angular/fire

Ardından app.module.ts dosyasını güncelleyin

    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 işlemi öğreticisini buradan kontrol edin

görüntü açıklamasını buraya girin


1

İçe Aktarma İşleminizi Şuradan Değiştirin:

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

Buna :

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

Bu benim sorunumu çözer.


0

Bunu app.modülüme götürüyorum. İthalattan sonra işler olmalı

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

Benim versiyonum:

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
import angularFirebaseStore 

içinde app.module.tsve hizmet gibi bir sağlayıcı olarak ayarlayın


0

Ionic Uygulamama firebase eklerken de aynı sorunu yaşadım . Sorunu çözmek için şu adımları izledim:

npm install @angular/fire firebase --save

Benim app / app.module.ts içinde :

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

Daha önce SETTINGS yerine FirestoreSettingsToken kullanıyorduk. Ancak bu hata çözüldü, şimdi AYARLAR kullanıyoruz. ( bağlantı )

Benim içinde app / hizmet / myService.ts I olarak içe:

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

Nedense vscode onu "@ angular / fire / firestore / firestore" olarak içe aktarıyordu, I "@ angular / fire / firestore" için değiştirdikten sonra; sorun çözüldü!

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.