我的目标是从数据库中获取所有日期,从最新到最旧的日期进行组织,以该顺序从数据库中获取所需的信息,然后发送给客户端。该代码在服务器端起作用,并且所有信息都是正确的。我只需要发送给我的客户。我的客户端接收字符串和我发送的任何内容,我认为问题出在我的返回语句所在的位置。谢谢任何尝试帮助我的人。
这是我的服务器端代码:
exports.loadNewestPlaylist = functions.https.onCall((request, response) => {
try {
var dates = [];
var Info = [];
var query = admin.database().ref().orderByKey();
query.once("value")
.then(function (snapshot) {
snapshot.forEach(function (snapshot) {
if (dates.indexOf(snapshot.child("Date").val()) > -1) {}
else {
dates.push(snapshot.child("Date").val());
dates.sort(date_sort_asc);
}
});
dates.forEach(function (date) {
query.once("value")
.then(function (snapshot) {
snapshot.forEach(function (snapshot) {
if (date === snapshot.child("Date").val()) {
Info.push(snapshot.child("Url").val(), snapshot.key);
}
});
});
});
return Info;
});
var date_sort_asc = function (date1, date2) {
if (date1 > date2) return 1;
if (date1 < date2) return -1;
return 0;
};
}
catch (error) {
console.error(error);
}
});
答案 0 :(得分:0)
由于@DougStevenson,我终于得到了答案!
try {
var dates = [];
var Info = [];
var query = admin.database().ref().orderByKey();
return new Promise((resolve, reject) => {
query.once("value").then(function (snapshot) {
snapshot.forEach(function (snapshot) {
if (dates.indexOf(snapshot.child("Date").val()) > -1) { }
else {
dates.push(snapshot.child("Date").val());
dates.sort(date_sort_asc);
}
});
dates.forEach(function (date) {
snapshot.forEach(function (snapshot) {
if (date === snapshot.child("Date").val()) {
Info.push(snapshot.child("Url").val(), snapshot.key);
}
});
});
resolve(Info);
});
});
loadNewestPlaylist().then(result => {
return result;
});
var date_sort_asc = function (date1, date2) {
if (date1 > date2) return 1;
if (date1 < date2) return -1;
return 0;
};
}
catch (error) {
console.error(error);
}
我需要使用promise才能将信息发送回客户端。
如果有人遇到此问题,我建议给他们阅读一些有用的链接。