Я изучаю 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)
Я пробовал погуглить, но не нашел точного решения, у меня ничего не работало :(,
Вот что я сделал: 1) Установленная версия узла 8.9.1 2) npm install -g @ angular / cli -> Version 1.5.2 3) ng new 'project-name' 4) npm install angularfire2 firebase --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, и я получаю указанную выше ошибку ...
angular
firebase
google-cloud-firestore
angularfire2
разработчик
источник
источник
Ответы:
Вы должны добавить
providers: [AngularFirestore]
вapp.module.ts
.источник
import
ИнгиAngularFirestoreModule
, как документация говорит, что предположительно заботится обо всем , в том числе декларирования вAngularFirestore
качестве поставщика.CTRL+C
ionic serve
У меня была такая же проблема, и она решена ниже.
Старый сервисный код:
Обновленный рабочий сервисный код:
источник
providedIn
аргумент доступен только в Angular 6 и выше.Открыть:
./src/app/app.module.ts
и импортировать модули Firebase вверху:
И ОЧЕНЬ ВАЖНО: не
забудьте обновить импорт в NgModule:
Попробуйте, теперь он работает.
Для получения подробной информации следуйте документации angularfire2 :
https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
Удачи!
источник
Для меня странным было то, что у меня был поставщик: [], но именно тег HTML, использующий поставщика, был причиной ошибки. Я имею в виду красную рамку ниже:
Оказывается, у меня было два класса в разных компонентах с одним и тем же именем файла «employee-list.component.ts», поэтому проект скомпилировался нормально, но все ссылки были испорчены.
источник
Добавление
AngularFirestoreModule.enablePersistence()
в раздел импорта решило мою проблему:источник
Я решил эту проблему, просто удалив firestore из:
в моем файле component.ts. только как использовать:
это тоже может быть вашей проблемой.
источник
Для AngularFire2 Последняя версия
устанавливать AngularFire2
Затем обновите app.module.ts файл
Ознакомьтесь с руководством по работе с FireStore CRUD здесь
источник
Измените свой импорт из:
К этому :
Это решит мою проблему.
источник
Я переношу это в свой app.module. После импорта должно быть работа
Моя версия:
источник
in
app.module.ts
и установите его как сервис, подобный провайдеруисточник
У меня была такая же проблема при добавлении firebase в мое приложение Ionic . Чтобы решить проблему, я выполнил следующие действия:
В моем приложении / app.module.ts :
Ранее мы использовали FirestoreSettingsToken вместо SETTINGS. Но эта ошибка решена, теперь мы используем НАСТРОЙКИ. ( ссылка )
В моем приложении / services / myService.ts я импортировал как:
По какой-то причине vscode импортировал его как «@ angular / fire / firestore / firestore»; I После изменения на «@ angular / fire / firestore»; проблема решена!
источник