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 ...
angular
firebase
google-cloud-firestore
angularfire2
Développeur
la source
la source
Réponses:
Vous devez ajouter
providers: [AngularFirestore]
àapp.module.ts
.la source
import
faireAngularFirestoreModule
, comme le dit la documentation, qui s'occupe vraisemblablement de tout, y compris la déclaration enAngularFirestore
tant que fournisseur.CTRL+C
leionic serve
et le relancer ... (cela arrive souvent pour une raison quelconque depuis Ionic 3 ..)J'ai eu le même problème et ci-dessous est résolu.
Ancien code de service:
Code de service de travail mis à jour:
la source
providedIn
argument n'est disponible que dans Angular 6 et plus.Ouvrir:
./src/app/app.module.ts
et importez les modules Firebase en haut:
Et TRÈS IMPORTANT:
n'oubliez pas de mettre à jour les 'importations' dans NgModule:
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!
la source
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:
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.
la source
L'ajout
AngularFirestoreModule.enablePersistence()
de la section d'importation a résolu mon problème:la source
J'ai résolu ce problème en supprimant simplement Firestore de:
dans mon fichier component.ts. comme utilisation uniquement:
cela peut aussi être votre problème.
la source
Pour AngularFire2 Dernière version
Installez AngularFire2
Puis mettez à jour le fichier app.module.ts
Consultez le didacticiel de fonctionnement du FireStore CRUD ici
la source
Modifiez votre importation depuis:
Pour ça :
Cela résout mon problème.
la source
Je l'apporte à mon app.module. Après les importations, cela devrait être des travaux
Ma version:
la source
dans
app.module.ts
et le définir comme un fournisseur comme le servicela source
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:
Dans mon app / app.module.ts :
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:
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!
la source