我正在学习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发球,我得到上面的错误…
:打开。/ src / app / app.module.ts
并在顶部导入Firebase模块:
Import {environment} from '../environments/environment';
import {AngularFireModule} from angularfire2;
import {angularfirestore} 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
好运!
我把它放到我的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
在我的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”之后;问题解决了!