NullInjectorError : AngularFirestore에 대한 공급자가 없습니다.


129

오류 수정에 대한 도움말을 찾고 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'
  }
};

그런 다음 제공하고 위의 오류가 발생합니다 ...


각도 7+와 경우 FireStore CRUD 작업이 예를 확인 freakyjolly.com/...
코드 스파이에게

답변:


242

당신은 추가해야합니다 providers: [AngularFirestore]에서 app.module.ts.

@NgModule({
  imports: [
    BrowserModule,
    AngularFireModule.initializeApp(environment.firebase)
  ],
  declarations: [ AppComponent ],
  providers: [AngularFirestore],
  bootstrap: [ AppComponent ]
})
export class AppModule {}

AngularFirestore : ([object Object],?)에 대한 모든 매개 변수를 확인할 수 없습니다. 이 오류가 다시 ..
개발자


1
마침내 그것은 위의 링크와 함께 일했습니다 @Sajeetharan
개발자

1
문서에 나와 있듯이 아마도 공급자로 선언하는 것을 포함하여 모든 것을 처리 import하는 대신을 수행해야하는 이유는 무엇입니까? AngularFirestoreModuleAngularFirestore

1
거기 이미 나를 위해, 무엇을 단순히이었다 해결 (지금 이오니아 3 이후 어떤 이유로 자주 발생합니다 ..) ... 그리고 그것을 다시 시작CTRL+Cionic serve
리키 레위

25

나는 같은 문제가 있었고 아래가 해결되었습니다.

이전 서비스 코드 :

@Injectable()

업데이트 된 작동 서비스 코드 :

@Injectable({
  providedIn: 'root'
})

다음 메시지를 표시합니다. "(TS) 0 개의 인수를 예상했지만 1 개를 얻었습니다."
Simon

1
새로운 providedIn인수는 Angular 6 이상에서만 사용할 수 있습니다.
James

9

열기 : ./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
행운을 빕니다!


4

나에게 이상한 점은 provider : []가 있었지만 공급자를 사용하는 HTML 태그가 오류의 원인이었습니다. 아래의 빨간색 상자를 참조하고 있습니다. 여기에 이미지 설명 입력

동일한 "employee-list.component.ts"파일 이름을 가진 서로 다른 구성 요소에 두 개의 클래스가 있으므로 프로젝트가 잘 컴파일되었지만 참조가 모두 엉망이되었습니다.


2

AngularFirestoreModule.enablePersistence()가져 오기 섹션에 추가하면 내 문제가 해결되었습니다.

imports: [
    BrowserModule, AngularFireModule, 
    AngularFireModule.initializeApp(config),
    AngularFirestoreModule.enablePersistence()
]

2

다음 에서 firestore 를 제거하여이 문제를 해결했습니다 .

import { AngularFirestore } from '@angular/fire/firestore/firestore';

내 component.ts 파일에서. 사용으로 만 :

import { AngularFirestore } from '@angular/fire/firestore';

이것은 또한 당신의 문제가 될 수 있습니다.


1

대한 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 { }

여기에서 FireStore CRUD 작동 자습서를 확인 하십시오.

여기에 이미지 설명 입력


1

다음에서 가져 오기 변경 :

import { AngularFirestore } from '@angular/fire/firestore/firestore';

이에 :

import { AngularFirestore } from '@angular/fire/firestore';

이것은 내 문제를 해결합니다.


0

나는 그것을 내 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


0

Ionic 앱에 firebase를 추가하는 동안 동일한 문제가 발생했습니다 . 문제를 해결하기 위해 다음 단계를 따랐습니다.

npm install @angular/fire firebase --save

app / app.module.ts에서 :

...
import { AngularFireModule } from '@angular/fire';
import { environment } from '../environments/environment';
import { AngularFirestoreModule, SETTINGS } from '@angular/fire/firestore';

@NgModule({
  declarations: [AppComponent],
  entryComponents: [],
  imports: [
    BrowserModule, 
    AppRoutingModule,
    AngularFireModule.initializeApp(environment.firebase),
    AngularFirestoreModule
  ],
  providers: [
    { provide: SETTINGS, useValue: {} }
  ],
  bootstrap: [AppComponent]
})

이전에는 SETTINGS 대신 FirestoreSettingsToken을 사용했습니다. 그러나 그 버그가 해결되었으므로 이제는 SETTINGS를 사용합니다. ( 링크 )

app / services / myService.ts에서 에서 다음과 같이 가져 왔습니다.

import { AngularFirestore } from "@angular/fire/firestore";

어떤 이유로 vscode는 그것을 "@ angular / fire / firestore / firestore"로 가져 왔습니다; 나는 "@ angular / fire / firestore"로 변경 한 후; 문제가 해결되었습니다!

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.