NullInjectorError: Tidak ada penyedia untuk AngularFirestore

131

Saya belajar Angular untuk mencari bantuan dalam memperbaiki kesalahan: Saya mengikuti tautan ini: https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md untuk membuat sudut kecil aplikasi dengan angular2 dan angularfirestore2

tetapi ketika saya menekan servis, saya mendapatkan kesalahan di bawah ini di konsol browser ..

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)

Saya mencoba googling tetapi tidak menemukan solusi yang tepat tidak ada yang berhasil untuk saya :(,

Inilah yang saya ikuti: 1) Instal Node Versi 8.9.1 2) npm install -g @ angular / cli -> Versi 1.5.2 3) ng baru 'nama-proyek' 4) npm install angularfire2 firebase --save

Berikut adalah file app.module.ts saya:

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

environment.ts:

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

lalu ng serve, dan saya mendapatkan error di atas ...

Pengembang
sumber
Periksa Contoh ini untuk operasi CRUD FireStore dengan Angular 7+ freakyjolly.com/…
Code Spy

Jawaban:

243

Anda harus menambahkan providers: [AngularFirestore]di app.module.ts.

@NgModule({
  imports: [
    BrowserModule,
    AngularFireModule.initializeApp(environment.firebase)
  ],
  declarations: [ AppComponent ],
  providers: [AngularFirestore],
  bootstrap: [ AppComponent ]
})
export class AppModule {}
Sajeetharan
sumber
Tidak dapat menyelesaikan semua parameter untuk AngularFirestore: ([Object Object],?). kesalahan ini lagi ..
Pengembang
1
akhirnya berhasil dengan tautan di atas terima kasih @Sajeetharan
Pengembang
1
Mengapa saya harus melakukan itu, bukan importing AngularFirestoreModule, sebagai dokumentasi mengatakan, yang mungkin mengurus semuanya termasuk mendeklarasikan AngularFirestoresebagai penyedia.
1
bagi saya itu sudah ada di sana, apa yang dipecahkan itu hanya CTRL+Csatu ionic servedan peluncuran itu ... (sering terjadi karena beberapa alasan sejak Ionic 3 ..)
Ricky Levi
26

Saya memiliki masalah yang sama dan di bawah ini teratasi.

Kode Layanan Lama:

@Injectable()

Kode Layanan kerja yang diperbarui:

@Injectable({
  providedIn: 'root'
})
sunleo
sumber
menunjukkan kepada saya pesan berikut: "(TS) Diharapkan 0 argumen, tetapi mendapat 1."
Simon
1
providedInArgumen baru hanya tersedia di Angular 6 dan lebih tinggi.
Yakobus
9

Buka: ./src/app/app.module.ts
Dan impor Modul Firebase di bagian atas:

impor { lingkungan } dari '../environments/environment';
impor { AngularFireModule } dari 'angularfire2';
impor { AngularFirestoreModule } dari 'angularfire2 / firestore';

Dan SANGAT PENTING:
Ingatlah untuk memperbarui 'impor' di NgModule:

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

Cobalah, sekarang akan berhasil.
Untuk informasi lebih lanjut, ikuti dokumentasi angularfire2 :
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
Selamat mencoba!

FredericoAlvesJS
sumber
4

Hal yang aneh bagi saya adalah saya memiliki penyedia: [], tetapi tag HTML yang menggunakan penyedia itulah yang menyebabkan kesalahan. Saya mengacu pada kotak merah di bawah ini: masukkan deskripsi gambar di sini

Ternyata saya memiliki dua kelas dalam komponen yang berbeda dengan nama file "employee-list.component.ts" yang sama sehingga proyek dapat dikompilasi dengan baik, tetapi semua referensinya kacau.

Gen
sumber
2

Menambahkan AngularFirestoreModule.enablePersistence()di bagian impor menyelesaikan masalah saya:

imports: [
    BrowserModule, AngularFireModule, 
    AngularFireModule.initializeApp(config),
    AngularFirestoreModule.enablePersistence()
]
Ravichandran J
sumber
2

Saya memecahkan masalah ini dengan hanya menghapus firestore dari:

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

di file component.ts saya. sebagai hanya digunakan:

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

ini juga bisa menjadi masalahmu.

Aman Gupta
sumber
1

Untuk AngularFire2 versi terbaru

Instal AngularFire2

$ npm install --save firebase @angular/fire

Kemudian perbarui file 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 { }

Lihat tutorial pengoperasian CRUD FireStore di sini

masukkan deskripsi gambar di sini

Kode Spy
sumber
1

Ubah Impor Anda Dari:

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

Untuk ini :

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

Ini memecahkan masalah saya.

TaSvet
sumber
0

Saya bawa itu ke app.module saya. Setelah impor itu harus berfungsi

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

Versi Saya:

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
Christoph Schöni
sumber
0
import angularFirebaseStore 

di app.module.tsdan mengaturnya sebagai penyedia seperti layanan

satywan kumar
sumber
0

Saya mengalami masalah yang sama saat menambahkan firebase ke Aplikasi Ionic saya . Untuk memperbaiki masalah, saya mengikuti langkah-langkah berikut:

npm install @angular/fire firebase --save

Di app / app.module.ts saya :

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

Sebelumnya kami menggunakan FirestoreSettingsToken sebagai ganti SETTINGS. Tapi bug itu teratasi, sekarang kami menggunakan SETELAN. ( tautan )

Di app / services / myService.ts saya, saya mengimpor sebagai:

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

Untuk beberapa alasan vscode mengimpornya sebagai "@ angular / fire / firestore / firestore"; I Setelah mengubahnya menjadi "@ angular / fire / firestore"; masalah teratasi!

Diego Herrera
sumber