#web #firebase #firebase-realtime-database
#web #firebase #firebase-база данных в реальном времени
Вопрос:
У меня есть следующий объект:
root: {
id1: { /* this is an autogenerated id by Firebase */
name1: "abc",
name2: "xyz"
},
id2: {
name1: "abc",
name2: "xyz"
},
id3: {
name1: "abc",
name2: "xyz"
},
}
Мой код для получения всего снимка:
getRoot () {
firebase.database ().ref ('roots/')
.on('value', function (snapshot) {
console.log (snapshot.val());
})
}
Все идеально. Я получил каждый объект из корневого компонента, но я не могу понять, как получить доступ к идентификаторам и их дочерним элементам? Спасибо!
Ответ №1:
Я не помнил, что опубликовал этот вопрос. Я узнал, как это сделать давным-давно.
Вот код, который выполнит эту работу:
Обслуживание:
myFunction () {
var ref = firebase.database ().ref ('roots')
return new Promise ((resolve, reject) => {
ref.on ('value', function (snapshot) {
if (snapshot.val () == null) {
reject (null);
} else {
var list = new Array ();
snapshot.forEach (function (data) {
var item = {
key: data.key, //this is to get the ID, if needed
name1: data.val ().name1,
name2: data.val ().name2,
}
list.push (item);
});
resolve (list);
}
});
});
}
Компонент:
this.myService.myFunction ().then (objects => {
this.objects = objects;
for (let obj of this.objects) {
console.log (obj.key);
}
}).catch (error => {
alert ('Nothing found');
})
Желаю вам счастливого кодирования!