javascript - Ionic 3 Angular Fire Payload.val() 返回 null

标签 javascript angular firebase ionic-framework firebase-realtime-database

我正在使用 Firebase 数据库来存储个人资料信息。如何检查当前个人资料是否已填写或为空?目前我正在使用 profile.payload.val(),如果填写了配置文件,它应该返回 true,但在这两种情况下都返回 null。

数据.service.ts

import { Injectable } from '@angular/core';
import { AngularFireDatabase, AngularFireObject } from 'angularfire2/database';
import { User } from 'firebase/app';
import { Profile } from '../../models/profile/profile.interface';

@Injectable()
export class DataService {

  profileObject: AngularFireObject<Profile>

  constructor(private database: AngularFireDatabase) {
  }

  getProfile(user: User) {
    this.profileObject = this.database.object(`/profiles/${user.uid}`);

    return this.profileObject.snapshotChanges();
  }

}

登录.ts

import { Component } from '@angular/core';
import { IonicPage, NavController, NavParams, ToastController } from 'ionic-angular';
import { LoginResponse } from '../../models/login/login-response.interface'
import { DataService } from '../../providers/data/data.service';
import { User } from 'firebase/app';
import { Subscription } from 'rxjs/Subscription';

@IonicPage()
@Component({
  selector: 'page-login',
  templateUrl: 'login.html',
})
export class LoginPage {

  constructor(
    private data: DataService,
    private toast: ToastController, 
    private navCtrl: NavController, 
    private navParams: NavParams) {
  }

  login(event: LoginResponse) {
    if(!event.error) {
      this.toast.create({
        message: `Welcome to Beep, ${event.result.email}`,
        duration: 3000
      }).present();

      this.data.getProfile(<User>event.result).subscribe(profile => {
        console.log(profile.payload.val());
        profile.payload.val() ? this.navCtrl.setRoot('TabsPage') : this.navCtrl.setRoot('EditProfilePage');
      })
    } 
    else {
      this.toast.create({
        message: event.error.message,
        duration: 3000
      }).present();
    }
  }
}

最佳答案

如果你想访问数据,你需要使用

this.data.getProfile(<User>event.result).subscribe(profile => {
            console.log(profile.payload.payload.data());      
          })

引用号:https://github.com/angular/angularfire2/blob/master/docs/firestore/collections.md

关于javascript - Ionic 3 Angular Fire Payload.val() 返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51613329/

相关文章:

angular - angular2中的可投影节点是什么

javascript - *ngFor 中的 Angular 2 函数表达式

javascript - Angular 外部 js 库调用 Document.Ready

javascript - 仅下载具有子 key 的 Firebase 快照

java - 如何在Bazel BUILD中使用gradle的apply插件?

java - Lobo Cobra HtmlPanel 在 JavaScript 操作后不更新 GUI

javascript - Angular 日期最小值未被强制执行

javascript - 如何在javascript中获取对象数组中的最大值和最小值?

javascript - 将函数的结果添加到数组中

java - 如何从 Firebase 数据库获取特定值(数据)