节点 Js 链接响应



我正在尝试在循环中进行数据库调用,并希望将该数据添加到一个对象中,然后将该对象发送给用户,但我在用户端只得到一个空对象。 我已经将这个异步响应检查到javascript NodeJS中的循环中

router.get('/collection', (req, res) => {
const Data = {}
Section.find({})
.then(sections => {
sections.map(section => {
let id = section._id;
Product.find({section: id})
.then(products => {
// console.log(products)
Data[section.title] = {
title: section.title,
routeName: section.title,
id,
items: products
}
console.log(Data)
})
.catch(err => {
return res.status(500).json(err)
})
})
return res.json(data)
})
.catch(err => {
return res.status(500).json(err)
})
})

我希望输出像:-

{
food : {
items: [...]
},
vegetable: {
items: [...]
}
}

食物和蔬菜是从数据库调用中获取的键,每个键中的项从对数据库的单独调用返回。

return res.json(data)

在任何映射的产品承诺被解析之前执行(还有一个拼写错误,因为你返回的是data而不是Data(。一种方法是映射find-promise,并在映射的数组上使用Promise.all。像这样:

router.get('/collection', (req, res) => {
const Data = {}
Section.find({})
.then(sections => {
const sectionProductPromises = sections.map(section => {
let id = section._id;
return Product.find({
section: id
})
.then(products => {                     
Data[section.title] = {
title: section.title,
routeName: section.title,
id,
items: products
}
});
});
return Promise.all(sectionProductPromises);    
})
.then(() => {
res.json(Data)
})
.catch(err => {
res.status(500).json(err)
});
});

最新更新