number - NullInjectorError: no hay proveedor para AngularFirestore
nullinjectorerror no provider for string (6)
Estoy aprendiendo Angular buscando ayuda para solucionar el error: estoy siguiendo este enlace: https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md para crear un pequeño angular aplicación con angular2 y angularfirestore2
pero cuando presiono ng serve obtengo el siguiente error en la consola del navegador ...
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)
Intenté buscarlo en Google pero no encontré la solución exacta, nada me funcionó :(,
Esto es lo que seguí: 1) Nodo instalado Versión 8.9.1 2) npm install -g @ angular / cli -> Versión 1.5.2 3) ng nuevo ''nombre-proyecto'' 4) npm install angularfire2 firebase --save
Aquí está mi archivo 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''
}
};
entonces ng servir, y obtengo el error anterior ...
Abierto:
./src/app/app.module.ts
E importe los módulos de Firebase en la parte superior:
importar { entorno } desde ''../environments/environment'';
importar { AngularFireModule } desde ''angularfire2'';
importar { AngularFirestoreModule } desde ''angularfire2 / firestore'';
Y MUY IMPORTANTE:
Recuerde actualizar ''importaciones'' en NgModule:
@NgModule({
declarations: [
AppComponent,
OtherComponent // Add other components here
...
],
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase, ''your-APP-name-here''),
AngularFirestoreModule
],
...
})
Pruébalo, ahora funcionará.
Para obtener información detallada, siga la documentación de
angularfire2
:
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
¡Buena suerte!
Agregar
AngularFirestoreModule.enablePersistence()
en la sección de importación resolvió mi problema:
imports: [
BrowserModule, AngularFireModule,
AngularFireModule.initializeApp(config),
AngularFirestoreModule.enablePersistence()
]
Debe agregar
providers: [AngularFirestore]
en
app.module.ts
.
@NgModule({
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase)
],
declarations: [ AppComponent ],
providers: [AngularFirestore],
bootstrap: [ AppComponent ]
})
export class AppModule {}
Lo extraño para mí fue que tenía el proveedor: [], pero la etiqueta HTML que usa el proveedor fue lo que estaba causando el error. Me refiero al cuadro rojo a continuación:
Resulta que tenía dos clases en diferentes componentes con el mismo nombre de archivo "employee-list.component.ts", por lo que el proyecto se compiló bien, pero todas las referencias estaban en mal estado.
Lo llevo a mi app.module. Después de las importaciones debería ser funciona
providers: [
{ provide: LocationStrategy, useClass: HashLocationStrategy },
{ provide: FirestoreSettingsToken, useValue: {} }
],
Mi 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
Tuve el mismo problema y a continuación se resuelve.
Código de servicio anterior:
@Injectable()
Código de servicio actualizado:
@Injectable({
providedIn: ''root''
})