[英]Promise .then() Not Waiting For Resolve() Of the Previous Promise In A Promise Chain
[英]Promise chain: parent promise is not waiting until child promise gets executed
我從一個 mongoDB 集合中獲取數據,在該響應中,我獲得了另一個集合數據的 Id,然后獲取並合並到一個對象中。
這是我的代碼,但不是等待 unitl child primise 被執行。
指導我解決我的代碼錯誤。
Courses.find({})
.then( course => {
//getting data from one collection
let CoursePromises = course.map(
key => {
new Promise((resolve, reject) => {
key.questions = []
//getting data from another collection via Id fetched from first collection.
let getQuestionsPromises = key.questionIds.map(
ques =>
new Promise((resolve, reject) => {
Questions.find({_id: ques._id})
.then(question => {
resolve(question)
}).catch(err => {
console.error("Error in question ", err.message)
})
})
)
Promise.all(getQuestionsPromises).then((data) => {
key.questions.push(data)
console.log("getQuestionsPromises", key)
})
resolve(key)
})
})
Promise.all(CoursePromises).then((data) => {
console.log("CoursePromises") // here promise is now wait for exection done
res.send({ status: true, data: course })
}
)
我得到了這樣的第一個集合響應:
{
"status": true,
"data": [
{
"_id": "5e3c1b683ac31f24da39e50a",
"courseName": "Test",
"duration": 1,
"createdBy": "John Die",
"__v": 0,
"updatedAt": "2020-02-06T13:58:00.906Z",
"createdAt": "2020-02-06T13:58:00.906Z",
"isAssigned": false,
"questions": []
"questionIds": [
{
"index": 1,
"_id": "5e3c1b683ac31f24da39e509"
}
]
}
]
}
使用 questionIds 我獲取另一個 recoed 並將該響應放入現有對象中,如下所示:
{
"status": true,
"data": [
{
"_id": "5e3c1b683ac31f24da39e50a",
"courseName": "Test",
"duration": 1,
"createdBy": "John Die",
"__v": 0,
"updatedAt": "2020-02-06T13:58:00.906Z",
"createdAt": "2020-02-06T13:58:00.906Z",
"isAssigned": false,
"questions": [
[
[
{
"_id": "5e3c1b683ac31f24da39e509",
"index": 1,
"isVideo": false,
"questionType": "MCQ",
"question": "Is this a demo question?",
"title": "Question",
"description": "this is question description",
"link": "",
"createdBy": "Harsh",
"updatedBy": "",
"__v": 0,
"updatedAt": "2020-02-06T13:58:00.521Z",
"createdAt": "2020-02-06T13:58:00.521Z",
"options": [
{
"one": "two"
}
]
}
]
]
],
"questionIds": [
{
"index": 1,
"_id": "5e3c1b683ac31f24da39e509"
}
]
}
]
}
在處理如此復雜的結構時,您應該遵循純async-await
語法。 還可以使用.lean()
將course
從貓鼬對象轉換為普通對象。
簡化代碼:
const course = await Courses.find({}).lean();
const coursePromises = course.map(async key => {
key.questions = [];
const getQuestionsPromises = key.questionIds.map(async ques => {
const question = await Questions.find({ _id: ques._id });
key.questions.push(question);
});
await Promise.all(getQuestionsPromises)
});
await Promise.all(coursePromises)
return res.send({ data: course })
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.