NullInjectorError: ไม่มีผู้ให้บริการสำหรับ AngularFirestore


131

ฉันกำลังเรียนรู้ 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)

ฉันลองใช้ googling แล้ว แต่ไม่พบวิธีแก้ปัญหาที่แน่นอนว่าไม่มีอะไรเหมาะกับฉัน :(,

นี่คือสิ่งที่ฉันติดตาม: 1) ติดตั้ง Node เวอร์ชัน 8.9.1 2) npm install -g @ angular / cli -> เวอร์ชัน 1.5.2 3) ng ใหม่ 'project-name' 4) npm ติดตั้ง angularfire2 firebase - บันทึก

นี่คือไฟล์ 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'
  }
};

จากนั้นก็ให้บริการและฉันได้รับข้อผิดพลาดข้างต้น ...


ตรวจสอบตัวอย่างนี้สำหรับการทำงานของ FireStore CRUD ด้วย Angular 7+ freakyjolly.com/…
Code Spy

คำตอบ:


244

คุณควรเพิ่มใน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ไอเอ็นจีAngularFirestoreModuleเป็นเอกสารกล่าวว่าซึ่งสันนิษฐานว่าจะดูแลทุกอย่างรวมทั้งการประกาศAngularFirestoreเป็นผู้ให้บริการ

1
สำหรับฉันมันมีอยู่แล้วสิ่งที่แก้ไขได้เป็นเพียงและสังข์มัน ... (มักจะเกิดขึ้นด้วยเหตุผลบางอย่างนับตั้งแต่ไอออนิก 3 .. )CTRL+Cionic serve
ริคกี้ลีวายส์

26

ฉันมีปัญหาเดียวกันและด้านล่างได้รับการแก้ไข

รหัสบริการเก่า:

@Injectable()

อัปเดตรหัสบริการที่ใช้งานได้:

@Injectable({
  providedIn: 'root'
})

แสดงให้ฉันเห็นข้อความต่อไปนี้: "(TS) คาดหวัง 0 อาร์กิวเมนต์ แต่ได้รับ 1"
Simon

1
providedInอาร์กิวเมนต์ใหม่มีให้เฉพาะใน Angular 6 ขึ้นไป
เจมส์

9

เปิด: ./src/app/app.module.ts
และนำเข้าโมดูล Firebase ที่ด้านบน:

นำเข้า { สภาพแวดล้อม } จาก "../en Environment/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 ที่ใช้ผู้ให้บริการเป็นสาเหตุของข้อผิดพลาด ฉันหมายถึงกล่องสีแดงด้านล่าง: ใส่คำอธิบายภาพที่นี่

ปรากฎว่าฉันมีสองคลาสในคอมโพเนนต์ที่แตกต่างกันโดยมีชื่อไฟล์ "staff-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

ฉันมีปัญหาเดียวกันในขณะที่เพิ่ม firebase ในแอพIonicของฉัน เพื่อแก้ไขปัญหาฉันทำตามขั้นตอนเหล่านี้:

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

ก่อนหน้านี้เราใช้ FirestoreSettingsToken แทน SETTINGS แต่ข้อบกพร่องนั้นได้รับการแก้ไขแล้วตอนนี้เราใช้การตั้งค่า ( ลิงค์ )

ในแอป / บริการ / 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.