javascript - 类型 'FirebaseApp' 中缺少“性能”

标签 javascript angular firebase ionic-framework angularfire2

我正在尝试在我的应用程序中连接 firebase,但我遇到了同样的错误,我尝试了很多方法,但都没有奏效。 首先,我安装了 firebase 和 @angular/fire

npm install firebase @angular/fire --save

之后,我将environment.ts改成了

export const environment = {
  production: false,
  firebase: {
    apiKey: "XXXXXXXXXXXXXXXXXXXXXXXXX",
    authDomain: "XXXXXXXXXXXXXXXXXXXXXXXXXX",
    databaseURL: "XXXXXXXXXXXXXXXXXXXXXXXXXXXX",
    projectId: "XXXXXXXXXXXXXXXXXXXXXXXXXX",
    storageBucket: "XXXXXXXXXXXXXXXXXXXXXXXXX",
    messagingSenderId: "XXXXXXXXXXXXXXXXXXXX"
  }
};

正如文档所述。 (我放的是XX,但是在真实环境中。还是放正确的那个)。然后,我将 app.module.ts 更改为

import { NgModule } from '@angular/core';
...
import { AngularFireModule } from '@angular/fire';
import { environment } from '../environments/environment';

@NgModule({
  declarations: [AppComponent],
  entryComponents: [],
  imports: [BrowserModule, IonicModule.forRoot(), AppRoutingModule,
  AngularFireModule.initializeApp(environment.firebase, 'guarnice')],
  providers: [
    StatusBar,
    SplashScreen,
    { provide: RouteReuseStrategy, useClass: IonicRouteStrategy }
  ],
  bootstrap: [AppComponent]
})
export class AppModule {}

当我运行代码时

ionic serve

我遇到了错误。

ERROR in node_modules/@angular/fire/firebase.app.module.d.ts(17,22): error TS2420: Class 'FirebaseApp' incorrectly implements interface 'App'. Property 'performance' is missing in type 'FirebaseApp'.

然后我找了 firebase.app.module.d.ts

import { InjectionToken } from '@angular/core';
import { app, auth, database, firestore, functions, messaging, storage } from 'firebase/app';
export declare type FirebaseOptions = {
    [key: string]: any;
};
export declare type FirebaseAppConfig = {
    [key: string]: any;
};
export declare const FirebaseOptionsToken: InjectionToken<FirebaseOptions>;
export declare const FirebaseNameOrConfigToken: InjectionToken<string | FirebaseAppConfig | undefined>;
export declare type FirebaseDatabase = database.Database;
export declare type FirebaseAuth = auth.Auth;
export declare type FirebaseMessaging = messaging.Messaging;
export declare type FirebaseStorage = storage.Storage;
export declare type FirebaseFirestore = firestore.Firestore;
export declare type FirebaseFunctions = functions.Functions;
export declare class FirebaseApp implements app.App {
    name: string;
    options: {};
    auth: () => FirebaseAuth;
    database: (databaseURL?: string) => FirebaseDatabase;
    messaging: () => FirebaseMessaging;
    storage: (storageBucket?: string) => FirebaseStorage;
    delete: () => Promise<void>;
    firestore: () => FirebaseFirestore;
    functions: (region?: string) => FirebaseFunctions;
}
export declare function _firebaseAppFactory(options: FirebaseOptions, nameOrConfig?: string | FirebaseAppConfig | null): FirebaseApp;
export declare class AngularFireModule {
    static initializeApp(options: FirebaseOptions, nameOrConfig?: string | FirebaseAppConfig): {
        ngModule: typeof AngularFireModule;
        providers: {
            provide: InjectionToken<string | FirebaseAppConfig | undefined>;
            useValue: string | FirebaseAppConfig | undefined;
        }[];
    };
}

我不知道我必须如何修复它...我在 stackoverflow 和其他网站上看到了一些小提示,但没有一个有效。

这是我遵循的文档https://github.com/angular/angularfire2

Angular CLI: 7.3.8
Node: 10.15.3
OS: linux x64
Angular: 7.2.13
Ionic: 4.12.0

 Package                           Version
-----------------------------------------------------------
@angular-devkit/architect         0.12.4
@angular-devkit/build-angular     0.13.8
@angular-devkit/build-optimizer   0.13.8
@angular-devkit/build-webpack     0.13.8
@angular-devkit/core              7.2.4
@angular-devkit/schematics        7.2.4
@angular/cli                      7.3.8
@angular/fire                     5.1.2
@ngtools/webpack                  7.3.8
@schematics/angular               7.3.8
@schematics/update                0.13.8
rxjs                              6.4.0
typescript                        3.1.6
webpack                           4.29.0

最佳答案

这里是 firebaser

更新:此问题已在 AngularFire2 release 5.1.3 中修复.升级到此版本以解决此问题。


适用于 JavaScript 的 5.11.0 版 Firebase SDK 引入了导致 AngularFire2 中断的更改。 AngularFire2 团队在版本 5.1.3 中创建了一个修复程序。或者,您可以坚持使用 Firebase JavaScript SDK 的 v5.10.1 以避免冲突。

该问题已在 AngularFire2 存储库中得到跟踪,因此请在此处查看最新信息:https://github.com/angular/angularfire2/issues/2059 .

关于javascript - 类型 'FirebaseApp' 中缺少“性能”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55942238/

相关文章:

javascript - 三个JS : Create Triangle Strip

angular - 预检响应具有无效的 http 状态代码 401?

node.js - 具有实时和 WebSockets 的 Angular2 + Laravel

javascript - 我的代码不起作用。如何删除 Firebase 列表中的元素?

javascript - 无法读取未定义的属性 'auth'

jquery - 创建一个新的 Firebase 存储的唯一路径,并将其存储在数据库中?

javascript - 根据第一个下拉菜单禁用第二个下拉选项

javascript - 如何修复 Webpack 在生产环境中破坏我的代码?

c# - 将 JavaScript 与 C# 结合使用用于非基于浏览器的操作

Angular 2+ 是否可以避免全局 CSS?