NullInjectorError: Нет провайдера для AngularFirestore
Я изучаю Angular в поисках помощи в исправлении ошибки:
Я перехожу по этой ссылке: https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
создать небольшое угловое приложение с angular2 и angularfirestore2
но когда я нажимаю ng serve, в консоли браузера появляется следующая ошибка.
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)
Я попытался найти его в Google, но не нашел точного решения, у меня ничего не получалось :(,
Вот то, что я следовал:
1) Установленная версия узла 8.9.1
2) npm install -g @angular/cli → версия 1.5.2
3) нг новое имя проекта
4) npm установить пожарную базу angularfire2 --save
Вот мой файл 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'
}
};
тогда ng serve, и я получаю вышеуказанную ошибку...
Ответы
Ответ 1
Вы должны добавить providers: [AngularFirestore]
в app.module.ts
.
@NgModule({
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase)
],
declarations: [ AppComponent ],
providers: [AngularFirestore],
bootstrap: [ AppComponent ]
})
export class AppModule {}
Ответ 2
У меня была такая же проблема, и ниже решена.
Старый Сервисный Код:
@Injectable()
Обновлен рабочий Сервисный код:
@Injectable({
providedIn: 'root'
})
Ответ 3
Открыть: ./src/app/app.module.ts
И импортируйте модули Firebase вверху:
import { environment } из '../environments/environment';
импортировать { AngularFireModule } из 'angularfire2';
импортировать { AngularFirestoreModule } из 'angularfire2/firestore';
И ОЧЕНЬ ВАЖНО:
Не забудьте обновить "импорт" в NgModule:
@NgModule({
declarations: [
AppComponent,
OtherComponent // Add other components here
...
],
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase, 'your-APP-name-here'),
AngularFirestoreModule
],
...
})
Попробуй, теперь все заработает.
За подробной информацией обращайтесь к документации angularfire2:
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
Удачи!
Ответ 4
Для меня было странно, что у меня был провайдер: [], но тег HTML, который использует провайдера, вызывал ошибку. Я имею в виду красное поле ниже:
![введите описание изображения здесь]()
Оказывается, у меня было два класса в разных компонентах с тем же именем "employee-list.component.ts", и поэтому проект был составлен отлично, но ссылки были испорчены.
Ответ 5
Добавление AngularFirestoreModule.enablePersistence()
в раздел импорта решило мою проблему:
imports: [
BrowserModule, AngularFireModule,
AngularFireModule.initializeApp(config),
AngularFirestoreModule.enablePersistence()
]
Ответ 6
Я решил эту проблему, просто удалив пожарный магазин из:
import { AngularFirestore } from '@angular/fire/firestore/firestore';
в моем файле component.ts.
только для использования:
import { AngularFirestore } from '@angular/fire/firestore';
это может быть и вашей проблемой.
Ответ 7
Я принимаю это в мой app.module. После импорта должно быть работает
providers: [
{ provide: LocationStrategy, useClass: HashLocationStrategy },
{ provide: FirestoreSettingsToken, useValue: {} }
],
Моя версия:
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
Ответ 8
Для AngularFire2 Последняя версия
Установите AngularFire2
$ npm install --save firebase @angular/fire
Затем обновите файл app.module.ts file
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 { }
Ознакомьтесь с руководством по работе с FireStore CRUD здесь
![enter image description here]()
Ответ 9
import angularFirebaseStore
в app.module.ts
и установите его в качестве службы, подобной поставщику