我正在尝试在循环k值等于users [0] .employees.length时发送响应,但是它正直接前进到最大长度,我该怎么解决
Userlist.find(queryObj).exec(function (err, users) {
if (err) {
return res.status(400).send({
message: errorHandler.getErrorMessage(err)
});
}
else {
console.log('found users list', users);
// res.json(users[0].employees);
var k=0;
var resparr=[]
for(var i=0;i<users[0].employees.length;i++){
k++;
User.find({"_id":users[0].employees[i]._id}).exec(function(err,user){
resparr=resparr.concat(user);
console.log("resparray:",k,resparr.length,i,users[0].employees.length)
if(k==users[0].employees.length)
{
console.log("success",resparr)
res.json(resparr);
}
})
}
}
});
答案 0 :(得分:0)
您正在同步循环内使用异步函数调用。循环将始终在调用回调函数之前结束。
您将需要某种异步循环。对于本机解决方案,您可以使用Promises:
const getUser = (id) => {
return new Promise((resolve, reject) => {
User.find({ '_id': id })
.exec((err, user) => {
if (err) reject(err);
else resolve(user);
});
});
};
const promises = users[0].employees.map(({ _id: id }) => getUser(id));
Promise.all(promises)
.then(users => res.json(users))
.catch(err);
对于node.js中的实用程序包,我建议将软件包async
用于基于回调的解决方案,或者将bluebird
用于Promises。两者都有.map
函数,非常适合此用例。