tddatatableservice number nullinjectorerror logger injector for error angular firebase google-cloud-firestore angularfire2

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