Причиной вашей проблемы является неправильная область видимости объекта this
в вашей функции обратного вызова firebase
. Это на самом деле относится к Firebase.Promise . Вам необходимо сохранить ссылку на this
со ссылкой на ваш класс, а затем использовать ее в обратном вызове firebase
:
export class Tab1Page {
name: string;
grade: number;
points: number;
empList: Array<{name: string, grade: number, points: number}> = [];
constructor() {
const usersRef = firebase.database().ref('/users/');
const ref = usersRef.orderByChild('points');
const self = this;
ref.once('value').then(function(snap) {
snap.forEach(function (childSnap) {
const pkey = childSnap.key;
// returns 'hJfEgXkyaKPckchL3kx8rpZ58Ew2'
const keyRef = firebase.database().ref('/users/' + pkey);
const ref2 = keyRef.orderByChild('name');
ref2.once('value').then(function(snap) {
snap.forEach(function (childSnap) {
const key = childSnap.key;
//returns -LV6c8E5rRD4_mQqsb6Q
const firebaseRef = firebase.database().ref('/users/' + pkey + '/' + key);
firebaseRef.once('value').then(function(snapshot) {
const name = snapshot.val().name;
const grade = snapshot.val().grade;
const points = snapshot.val().points;
// returns 'Emily Blunt', 12, 20
self.empList.push({
name: name,
grade: grade,
points: points
});
});
});
});
});
});
}
}
Вы можете увидеть этот другой SO-ответ, чтобы узнать больше о привязке this
: Как работает этот keword