오류 수정에 대한 도움말을 찾고 Angular를 배우고 있습니다.이 링크를 따르고 있습니다 .https : //github.com/angular/angularfire2/blob/master/docs/install-and-setup.md
to create a angle small 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) 설치된 Node 버전 8.9.1 2) npm install -g @ angular / cli-> 버전 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'
}
};
그런 다음 제공하고 위의 오류가 발생합니다 …
답변
당신은 추가해야합니다 providers: [AngularFirestore]
에서 app.module.ts
.
@NgModule({
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase)
],
declarations: [ AppComponent ],
providers: [AngularFirestore],
bootstrap: [ AppComponent ]
})
export class AppModule {}
답변
나는 같은 문제가 있었고 아래가 해결되었습니다.
이전 서비스 코드 :
@Injectable()
업데이트 된 작동 서비스 코드 :
@Injectable({
providedIn: 'root'
})
답변
열기 : ./src/app/app.module.ts
상단에서 Firebase 모듈을 가져옵니다.
‘../environments/environment’에서 { 환경 } 가져 오기 ;
import { AngularFireModule } from ‘angularfire2’;
import { AngularFirestoreModule } from ‘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
행운을 빕니다!
답변
나에게 이상한 점은 provider : []가 있었지만 공급자를 사용하는 HTML 태그가 오류의 원인이었습니다. 아래의 빨간색 상자를 참조하고 있습니다.
동일한 “employee-list.component.ts”파일 이름을 가진 서로 다른 구성 요소에 두 개의 클래스가 있으므로 프로젝트가 잘 컴파일되었지만 참조가 모두 엉망이되었습니다.
답변
AngularFirestoreModule.enablePersistence()
가져 오기 섹션에 추가하면 내 문제가 해결되었습니다.
imports: [
BrowserModule, AngularFireModule,
AngularFireModule.initializeApp(config),
AngularFirestoreModule.enablePersistence()
]
답변
다음 에서 firestore 를 제거하여이 문제를 해결했습니다 .
import { AngularFirestore } from '@angular/fire/firestore/firestore';
내 component.ts 파일에서. 사용으로 만 :
import { AngularFirestore } from '@angular/fire/firestore';
이것은 또한 당신의 문제가 될 수 있습니다.
답변
대한 AngularFire2 최신 버전
AngularFire2 설치
$ npm install --save firebase @angular/fire
그런 다음 app.module.ts 파일을 업데이트 하십시오.
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 { }
![](http://daplus.net/wp-content/uploads/2023/04/coupang_part-e1630022808943-2.png)