ChatGPT解决这个技术问题 Extra ChatGPT

NullInjectorError:没有 AngularFirestore 的提供者

我正在学习 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)

我尝试用谷歌搜索它,但没有找到确切的解决方案,对我没有任何作用:(,

这是我遵循的:1)安装的节点版本 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) {}
}

环境.ts:

export const environment = {
  production: false,
  firebase: {
    apiKey: 'xxxxx',
    authDomain: 'aaaaaaa',
    databaseURL: 'bbbbbbbbbbbbbbbbbb',
    projectId: 'aaaaaaaaaaaaaa',
    storageBucket: 'aaaaaaaaaaaa',
    messagingSenderId: 'aaaaaaaaaaaaa'
  }
};

然后 ng 服务,我收到上述错误...


M
Michael

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

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

无法解析 AngularFirestore 的所有参数:([object Object], ?)。又是这个错误..
最后它与上面的链接一起工作,谢谢@Sajeetharan
为什么我需要这样做,而不是像文档中所说的那样 importing AngularFirestoreModule,它可能会处理所有事情,包括将 AngularFirestore 声明为提供程序。
对我来说它已经存在了,解决它的只是 CTRL+C ionic serve 并重新启动它......(自 Ionic 3 以来由于某种原因经常发生......)
s
sunleo

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

旧服务代码:

@Injectable()

更新的工作服务代码:

@Injectable({
  providedIn: 'root'
})

向我显示以下消息:“(TS)预期 0 个参数,但得到 1 个。”
新的 providedIn 参数仅在 Angular 6 及更高版本中可用。
如果可能值得注意此更改的作用。在不添加 providedIn: 'root' 的情况下,我们将类记录为可注入的。添加 providedIn: 'root' 使此类可在应用程序中的任何位置注入,从 root 开始。
@BluJIT 有什么理由你不想在任何地方注入一个类吗?
@enorl76 是的,它改变了依赖关系。例如,当您将应用程序构建成不同的模块时,您希望它的组件和服务在模块 importsproviders 中,而不是在 root 中。否则,它会破坏将应用程序结构化为不同模块的意义。
F
FredericoAlvesJS

打开:./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
祝你好运!


R
Ritu Gupta

简单的答案。

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

解决方案:

请将模块添加到 module.ts 文件中的 imports 数组中。在 modules.ts 文件中的 providers 数组中添加您想要使用的服务。

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

简单的答案是正确的,但解决方案是错误的。这将使您的代码快速无法维护
L
Liam

https://i.stack.imgur.com/1Sq7p.png

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


R
Ravichandran J

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

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

A
Aman Gupta

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

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

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

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

这也可能是您的问题。


C
Code Spy

对于 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

https://i.stack.imgur.com/6Ypyh.jpg


T
TaSvet

更改您的导入来源:

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

对此:

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

这解决了我的问题。


C
Christoph Schöni

我把它带到我的 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


M
Marcello B.
import angularFirebaseStore 

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


D
Diego Herrera

在将 Firebase 添加到 Ionic App 时,我遇到了同样的问题。为了解决这个问题,我按照以下步骤操作:

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。但是那个错误得到了解决,现在我们使用设置。 (link)

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

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

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


关注公众号,不定期副业成功案例分享
关注公众号

不定期副业成功案例分享

领先一步获取最新的外包任务吗?

立即订阅