我正在学习Angular,寻找修复错误的帮助: 我正在点击这个链接:https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md 使用angular2和angularfirestore2创建一个angular小应用

但是当我点击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——>版本为1.5.2 3) ng新的“项目名称” 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'
  }
};

然后ng发球,我得到上面的错误…


当前回答

在我的Ionic App中添加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]
})

之前我们使用FirestoreSettingsToken而不是SETTINGS。但是这个错误已经解决了,现在我们使用设置。(链接)

在我的app/services/myService。ts我导入为:

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

由于某种原因,vscode将它导入为“@angular/fire/firestore/firestore” 在把它改成“@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 { }

点击这里查看FireStore CRUD操作教程

我也有同样的问题,以下是解决。

旧服务代号:

@Injectable()

更新的工作服务代码:

@Injectable({
  providedIn: 'root'
})

在导入部分添加AngularFirestoreModule.enablePersistence()解决了我的问题:

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

在我的Ionic App中添加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]
})

之前我们使用FirestoreSettingsToken而不是SETTINGS。但是这个错误已经解决了,现在我们使用设置。(链接)

在我的app/services/myService。ts我导入为:

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

由于某种原因,vscode将它导入为“@angular/fire/firestore/firestore” 在把它改成“@angular/fire/firestore”之后;问题解决了!

import angularFirebaseStore 

在app.module.ts中,并将其设置为类似于service的提供者