NullInjectorError: No provider for AngularFirestore
NullInjectorError: No provider for AngularFirestore
我正在学习 Angular 寻求帮助来修复错误:
我正在关注这个 link : 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) 新 'project-name'
4) npm 安装 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 服务,我得到了上面的错误...
您应该在 app.module.ts
.
中添加 providers: [AngularFirestore]
@NgModule({
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase)
],
declarations: [ AppComponent ],
providers: [AngularFirestore],
bootstrap: [ AppComponent ]
})
export class AppModule {}
打开:./src/app/app.module.ts
并在顶部导入 Firebase 模块:
import { environment } from '../environments/environment';
import { AngularFireModule } from 'angularfire2';
import { AngularFirestoreModule } from 'angularfire2/firestore';
而且非常重要:
记得在 NgModule 中更新 'imports':
@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
祝你好运!
对我来说奇怪的是我有 provider:[]
,但使用提供商的 HTML 标签是导致错误的原因。我指的是下面的红框:
事实证明,我在不同的组件中有两个 类 具有相同的“employee-list.component.ts”文件名,因此项目编译正常,但引用全乱了。
在导入部分添加 AngularFirestoreModule.enablePersistence()
解决了我的问题:
imports: [
BrowserModule, AngularFireModule,
AngularFireModule.initializeApp(config),
AngularFirestoreModule.enablePersistence()
]
我有同样的问题,下面已解决。
旧服务代码:
@Injectable()
更新的工作服务代码:
@Injectable({
providedIn: 'root'
})
我把它带到我的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
对于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
我通过从以下位置删除 firestore 解决了这个问题:
import { AngularFirestore } from '@angular/fire/firestore/firestore';
在我的 component.ts 文件中。
仅供使用:
import { AngularFirestore } from '@angular/fire/firestore';
这也可能是您的问题。
import angularFirebaseStore
in app.module.ts
并将其设置为类似服务的提供者
更改导入自:
import { AngularFirestore } from '@angular/fire/firestore/firestore';
致此:
import { AngularFirestore } from '@angular/fire/firestore';
这解决了我的问题。
我在将 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。但是那个错误已经解决了,现在我们使用设置。 (link)
在我的 app/services/myService.ts 中,我导入为:
import { AngularFirestore } from "@angular/fire/firestore";
出于某种原因 vscode 将其导入为“@angular/fire/firestore/firestore”;我
将其更改为“@angular/fire/firestore”后;问题已解决!
简单回答。
每当遇到NullInjector error
。
原因总是 import/providers
是 missing
.
解决方案:
请在 module.ts
文件中的 imports
数组中添加模块。
在 modules.ts
文件中的 providers
数组中添加您要使用的服务。
@NgModule({})
export class SomeModule{
`imports:[]`,
`providers: []`
}
我正在学习 Angular 寻求帮助来修复错误: 我正在关注这个 link : 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) 新 'project-name' 4) npm 安装 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 服务,我得到了上面的错误...
您应该在 app.module.ts
.
providers: [AngularFirestore]
@NgModule({
imports: [
BrowserModule,
AngularFireModule.initializeApp(environment.firebase)
],
declarations: [ AppComponent ],
providers: [AngularFirestore],
bootstrap: [ AppComponent ]
})
export class AppModule {}
打开:./src/app/app.module.ts
并在顶部导入 Firebase 模块:
import { environment } from '../environments/environment';
import { AngularFireModule } from 'angularfire2';
import { AngularFirestoreModule } from 'angularfire2/firestore';
而且非常重要:
记得在 NgModule 中更新 'imports':
@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
祝你好运!
对我来说奇怪的是我有 provider:[]
,但使用提供商的 HTML 标签是导致错误的原因。我指的是下面的红框:
事实证明,我在不同的组件中有两个 类 具有相同的“employee-list.component.ts”文件名,因此项目编译正常,但引用全乱了。
在导入部分添加 AngularFirestoreModule.enablePersistence()
解决了我的问题:
imports: [
BrowserModule, AngularFireModule,
AngularFireModule.initializeApp(config),
AngularFirestoreModule.enablePersistence()
]
我有同样的问题,下面已解决。
旧服务代码:
@Injectable()
更新的工作服务代码:
@Injectable({
providedIn: 'root'
})
我把它带到我的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
对于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
我通过从以下位置删除 firestore 解决了这个问题:
import { AngularFirestore } from '@angular/fire/firestore/firestore';
在我的 component.ts 文件中。 仅供使用:
import { AngularFirestore } from '@angular/fire/firestore';
这也可能是您的问题。
import angularFirebaseStore
in app.module.ts
并将其设置为类似服务的提供者
更改导入自:
import { AngularFirestore } from '@angular/fire/firestore/firestore';
致此:
import { AngularFirestore } from '@angular/fire/firestore';
这解决了我的问题。
我在将 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。但是那个错误已经解决了,现在我们使用设置。 (link)
在我的 app/services/myService.ts 中,我导入为:
import { AngularFirestore } from "@angular/fire/firestore";
出于某种原因 vscode 将其导入为“@angular/fire/firestore/firestore”;我 将其更改为“@angular/fire/firestore”后;问题已解决!
简单回答。
每当遇到NullInjector error
。
原因总是 import/providers
是 missing
.
解决方案:
请在
module.ts
文件中的imports
数组中添加模块。在
modules.ts
文件中的providers
数组中添加您要使用的服务。
@NgModule({})
export class SomeModule{
`imports:[]`,
`providers: []`
}