[英]Node.js console.log() gives unpredictable answer
該功能可以搜索測試問題並匹配用戶給出的答案並存儲在數據庫中。 Console.log()以隨機順序顯示所有6個問題。 每次迭代的num值為6。 如果我在沒有從數據庫中找到任何內容的情況下執行console.log(num),那么我會正確顯示值1,2,3,4,5,6。
function(req,res){
var arr = [2,1,3,4,1,4],score=0, num=0;
Test.find({name:req.params.testnum}).
populate({
path: 'question',
model: 'Testques'
}).
exec(function(err,test){
console.log(test)
if(err){
res.status(500).send('DB error');
}
else{
arr.forEach(myFunction)
function myFunction(value){
num+=1;
Testques.find({Serialnum:num},function(err,ques){
console.log(num);
if(err){
console.log(err);
}
else{
console.log(ques);
console.log(ques[0].answer);
if(ques[0].answer == value){
score=score+4;
console.log(score);
}
}
})
}
}
})
}
我同意CRice對此有何評論 。 在回調的else中,您試圖運行一個同步的forEach
循環,但在其中運行了一個異步代碼塊(即: Testques.find
),這無法按您希望的方式工作。
一個不錯的解決方案是,使您的Mongoose調用(使用promisifying utils)繁多,然后一旦實現,要么使用Promise.all來解決這些排隊的Testques.find
的數組, Testques.find
發現您可以將其壓入其中。
否則,您還可以按照以下步驟進行操作:將forEach
參數內的函數移到該方法范圍之外的另一個方法,然后使用遞歸的基礎知識來實現您想要的目標。 它應該與此類似:
function cbIterator($index, arr, num, score) {
if ($index < arr.length) {
const value = arr[$index];
num++;
Testques.find({ Serialnum: num }, function (err, ques) {
console.log(num);
if (err) {
console.log(err);
}
else {
console.log(ques);
console.log(ques[0].answer);
if (ques[0].answer === value) {
score = score + 4;
console.log(score);
}
cbIterator($index + 1, arr, num, score);
}
});
}
return;
}
function myTestFunction(req, res) {
// A bit of ES6. Feel free to replace the const / let with var if you are not comfortable with those
const arr = [2, 1, 3, 4, 1, 4];
let score = 0, num = 0;
Test.find({ name: req.params.testnum })
.populate({
path: 'question',
model: 'Testques'
}).exec(function (error, test) {
if (error) {
res.status(500).send('DB Error');
} else {
let $index = 0;
cbIterator($index, arr, num, score);
}
});
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.