我习惯于与mySQL一起工作,通常我会做这样的事情:
function foo(userId){
$gender = getGender($userId);
//getGender returns result of SQL query: SELECT gender FROM users WHERE uid = $userId
return $gender;
}
这种方法与Firebase不起作用,因为它是异步的。我知道我可以做这样的事情:
ref.child(userId +'/gender').once('value').then(function(snap => {
doSomethingWithGender(snap.val());
});
但是,由于我使用的是两个或多个参数的函数,这是数据库查询的结果,因此此方法不会削减它。有没有办法将异步函数传递给函数,等到实现功能,然后执行函数?
更具体地说,我想实现这样的目标:
function compareUsers(u1,u2){
var totalScore = 0;
var n = countAnswers(u1,u2);
for(i = 1 ; i <= n ; i++){
var weight = compare(getResponse(u1, i), getResponse(u2, i));
totalScore = totalScore + weight;
}
var score = totalScore/n;
console.log(score);
}
function countAnswers(u1,u2){
var dimension = getMin(getMaxKey(u1), getMaxKey(u2));
}
function getMaxKey(uID){
var ref = db.ref("score/" + uID);
return ref.orderByChild('id').limitToLast(1).once("value").then(snap => {
return snap.key;
});
}
function getResponse(uID, qID){
var ref = db.ref("answer/" + uID + "/" + qid);
return ref.child('answer').once("value").then(snap => {
return snap.val();
});
}
您要寻找的是 Promise.all()
。Firebase的once()
方法返回承诺,Promise.all()
解决(即,一旦所有承诺您都解决了它的then()
方法(。
so:
Promise.all([getMaxKey(u1), getMaxKey(u2)]).then(function(keys) {
console.log(keys[0], keys[1]);
});
如果您处于async
上下文:
const keys = await Promise.all([getMaxKey(u1), getMaxKey(u2)]);
console.log(keys[0], keys[1]);