Неожиданное значение, импортированное модулем, добавьте аннотацию @ngmodule
Я создал ионное приложение, и в этом приложении я хочу подключиться firebase
с ионным приложением. но после настройки firebase
и ионное приложение у меня возникла проблема:
Неожиданное значение, импортированное модулем, добавьте аннотацию @ngmodule
Я импортировал базу данных более firebase
и теперь я хочу получить, а также добавить новые данные к этим данным
app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { HttpModule } from '@angular/http';
import { ErrorHandler, NgModule } from '@angular/core';
import { IonicApp, IonicErrorHandler, IonicModule } from 'ionic-angular';
import { SplashScreen } from '@ionic-native/splash-screen';
import { StatusBar } from '@ionic-native/status-bar';
import { MyApp } from './app.component';
import { HomePage } from '../pages/home/home';
import { AngularFireModule } from 'angularfire2';
// import { AngularFireModule } from 'angularfire2/src/angularfire2';
import { AngularFireDatabase, AngularFireDatabaseModule,FirebaseListObservable } from 'angularfire2/database';
@NgModule({
declarations: [
MyApp,
HomePage
],
imports: [
BrowserModule,
HttpModule,
IonicModule.forRoot(MyApp),
AngularFireModule,
AngularFireDatabase,
// AngularFireDatabaseModule,
FirebaseListObservable
],
bootstrap: [IonicApp],
entryComponents: [
MyApp,
HomePage
],
providers: [
StatusBar,
SplashScreen,
{provide: ErrorHandler, useClass: IonicErrorHandler}
]
})
export class AppModule {}
home.ts
import { Component } from '@angular/core';
import { NavController, ModalController, Platform } from 'ionic-angular';
import { AngularFireDatabase, AngularFireDatabaseModule, FirebaseListObservable} from 'angularfire2/database';
import 'rxjs/add/operator/map';
import * as firebase from 'firebase';
@Component({
selector: 'page-home',
templateUrl: 'home.html'
})
export class HomePage {
public movies : FirebaseListObservable<any[]>;
constructor(public navCtrl: NavController, private angFire: AngularFireDatabase, private modalCtrl : ModalController,private platform : Platform) {
}
ionViewDidLoad()
{
this.platform.ready()
.then(() =>
{
this.movies = this.angFire.list('/films');
});
}
addRecord()
{
let modal = this.modalCtrl.create('Modals');
modal.present();
}
editMovie(movie)
{
let params = { movie: movie, isEdited: true },
modal = this.modalCtrl.create('Modals', params);
modal.present();
}
deleteMovie(movie : any)
{
this.movies.remove(movie);
}
}
1 ответ
Решение
AngularFireDatabase
это поставщик, а не модуль. Вам нужно только импортировать AngularFireDatabaseModule
а не провайдер в вашем app.module.ts Также проверьте установочные документы
export const firebase: {
apiKey: '<your-key>',
authDomain: '<your-project-authdomain>',
databaseURL: '<your-database-URL>',
projectId: '<your-project-id>',
storageBucket: '<your-storage-bucket>',
messagingSenderId: '<your-messaging-sender-id>'
};
imports: [
BrowserModule,
HttpModule,
IonicModule.forRoot(MyApp),
AngularFireModule.initializeApp(firebase),
AngularFireDatabaseModule //this one
],
И в вашем массиве провайдеров в app.module.ts,
providers: [
AngularFireDatabase,
//...
]