NullInjectorError: aucun fournisseur pour AngularFirestore

131

J'apprends Angular à la recherche d'aide pour corriger l'erreur: je suis ce lien: https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md pour créer un petit angulaire application avec angular2 et angularfirestore2

mais quand je clique sur ng serve, j'obtiens l'erreur ci-dessous dans la console du navigateur.

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)

J'ai essayé de googler mais je n'ai pas trouvé la solution exacte, rien n'a fonctionné pour moi :(,

Voici ce que j'ai suivi: 1) Installed Node Version 8.9.1 2) npm install -g @ angular / cli -> Version 1.5.2 3) ng new 'project-name' 4) npm install angularfire2 firebase --save

Voici mon fichier 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'
  }
};

puis ng serve, et j'obtiens l'erreur ci-dessus ...

Développeur
la source
Consultez cet exemple pour les opérations CRUD FireStore avec Angular 7+ freakyjolly.com
Code Spy

Réponses:

243

Vous devez ajouter providers: [AngularFirestore]à app.module.ts.

@NgModule({
  imports: [
    BrowserModule,
    AngularFireModule.initializeApp(environment.firebase)
  ],
  declarations: [ AppComponent ],
  providers: [AngularFirestore],
  bootstrap: [ AppComponent ]
})
export class AppModule {}
Sajeetharan
la source
Impossible de résoudre tous les paramètres d'AngularFirestore: ([objet objet],?). cette erreur à nouveau ..
Développeur
1
enfin, cela a fonctionné avec le lien ci-dessus merci @Sajeetharan
Développeur
1
Pourquoi aurais-je besoin de faire cela, au lieu de le importfaire AngularFirestoreModule, comme le dit la documentation, qui s'occupe vraisemblablement de tout, y compris la déclaration en AngularFirestoretant que fournisseur.
1
pour moi, il était déjà là, ce qui a résolu c'était simplement CTRL+Cle ionic serveet le relancer ... (cela arrive souvent pour une raison quelconque depuis Ionic 3 ..)
Ricky Levi
26

J'ai eu le même problème et ci-dessous est résolu.

Ancien code de service:

@Injectable()

Code de service de travail mis à jour:

@Injectable({
  providedIn: 'root'
})
Sunleo
la source
me montre le message suivant: "(TS) Attendu 0 arguments, mais obtenu 1."
Simon
1
Le nouvel providedInargument n'est disponible que dans Angular 6 et plus.
James
9

Ouvrir: ./src/app/app.module.ts
et importez les modules Firebase en haut:

import { environnement } depuis '../environments/environment';
import { AngularFireModule } depuis 'angularfire2';
import { AngularFirestoreModule } depuis 'angularfire2 / firestore';

Et TRÈS IMPORTANT:
n'oubliez pas de mettre à jour les 'importations' dans NgModule:

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

Essayez-le, cela fonctionnera maintenant.
Pour des informations détaillées, suivez la documentation angularfire2 :
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
Bonne chance!

FredericoAlvesJS
la source
4

La chose étrange pour moi était que j'avais le fournisseur: [], mais la balise HTML qui utilise le fournisseur était ce qui causait l'erreur. Je fais référence à la boîte rouge ci-dessous: entrez la description de l'image ici

Il s'avère que j'avais deux classes dans des composants différents avec le même nom de fichier "employee-list.component.ts" et donc le projet s'est bien compilé, mais les références étaient toutes fausses.

Gène
la source
2

L'ajout AngularFirestoreModule.enablePersistence()de la section d'importation a résolu mon problème:

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

J'ai résolu ce problème en supprimant simplement Firestore de:

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

dans mon fichier component.ts. comme utilisation uniquement:

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

cela peut aussi être votre problème.

Aman Gupta
la source
1

Pour AngularFire2 Dernière version

Installez AngularFire2

$ npm install --save firebase @angular/fire

Puis mettez à jour le fichier 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 { }

Consultez le didacticiel de fonctionnement du FireStore CRUD ici

entrez la description de l'image ici

Espion de code
la source
1

Modifiez votre importation depuis:

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

Pour ça :

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

Cela résout mon problème.

TaSvet
la source
0

Je l'apporte à mon app.module. Après les importations, cela devrait être des travaux

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

Ma version:

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
la source
0
import angularFirebaseStore 

dans app.module.tset le définir comme un fournisseur comme le service

satywan kumar
la source
0

J'ai eu le même problème lors de l'ajout de firebase à mon application Ionic . Pour résoudre le problème, j'ai suivi ces étapes:

npm install @angular/fire firebase --save

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

Auparavant, nous utilisions FirestoreSettingsToken au lieu de SETTINGS. Mais ce bogue a été résolu, maintenant nous utilisons SETTINGS. ( lien )

Dans mon application / services / myService.ts, j'ai importé en tant que:

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

Pour une raison quelconque, vscode l'a importé sous le nom "@ angular / fire / firestore / firestore"; I Après l'avoir changé pour "@ angular / fire / firestore"; le problème a été résolu!

Diego Herrera
la source