NullInjectorError:没有AngularFirestore的提供者

时间:2017-11-19 18:08:47

标签: angular angularfire2

我正在学习Angular寻找修复错误的帮助: 我正在关注此链接:https://github.com/angular/angularfire2/blob/master/docs/install-and-setup.md 使用angular2和angularfirestore2

创建一个有角度的小应用程序

但是当我点击服务时,我在浏览器控制台中收到以下错误..

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)新的'项目名称' 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服务,我收到上述错误..

12 个答案:

答案 0 :(得分:127)

您应该在 providers: [AngularFirestore] 中添加 app.module.ts

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

答案 1 :(得分:9)

我遇到了同样的问题,下面的问题已解决。

旧服务代码:

 @Override
 public void onBindViewHolder(ViewHolder holder, int position) {

     //here position is unique for every item in the list, so, you can use it as a serial number
    // also, since it's starting from 0, you should add 1 with it, in case you wanna start from 1      

    // holder.textView2.setText(myDataList.get(position).getSerialNumber());
       holder.textView2.setText("S.No. "+(position+1));
 }

更新的工作服务代码:

@Injectable()

答案 2 :(得分:5)

打开:./src/app/app.module.ts
并在顶部导入Firebase模块:

  

从' ../ environments / environment'中导入{环境};   从' angularfire2'中导入{ AngularFireModule };

  从' angularfire2 / firestore'中导入{ AngularFirestoreModule };

非常重要:
请记得更新'进口'在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
祝你好运!

答案 3 :(得分:3)

对我来说奇怪的是我有提供者:[],但使用提供程序的HTML标记是导致错误的原因。我指的是下面的红色框: enter image description here

事实证明我在不同的组件中有两个类具有相同的“employee-list.component.ts”文件名,所以项目编译得很好,但引用都搞砸了。

答案 4 :(得分:2)

我通过从以下位置删除 firestore 解决了这个问题:

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

在我的component.ts文件中。 仅供使用:

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

这也是您的问题。

答案 5 :(得分:1)

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

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

答案 6 :(得分:1)

更改导入来源:

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

对此:

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

这解决了我的问题。

答案 7 :(得分: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

答案 8 :(得分:0)

对于 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操作教程here

enter image description here

答案 9 :(得分:0)

import angularFirebaseStore 

app.module.ts 中,并将其设置为类似服务的提供商

答案 10 :(得分: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。但是该错误已解决,现在我们使用SETTINGS。 (link

在我的 app / services / myService.ts 中,我导入为:

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

由于某种原因,vscode将其导入为“ @ angular / fire / firestore / firestore”;我 将其更改为“ @ angular / fire / firestore”后;问题解决了!

答案 11 :(得分:0)

简单的答案。

每当您遇到NullInjector error。 原因总是 import/providersmissing

解决方案:

  1. 请将模块添加到您的 imports 文件内的 module.ts 数组中。

  2. providers 文件内的 modules.ts 数组中添加您要使用的服务。

@NgModule({})
export class SomeModule{
 `imports:[]`,
`providers: []`
}