我試圖讓我的頭繞着node.js的異步本質。 我有一個明確的路線,我知道不會給我需要的數據。基本上,第一個mysql查詢按預期工作100%,並且在res.json中返回的json數據是正確的。然而,在第一個mysql函數中,我調用了另一個函數'getOrderLines()',它總是返回'{「Item':[]}',而不是我期望的數據。Node.js處理異步
我知道這是因爲節點的異步性質而發生的,但是我似乎無法解決這個問題,我查看了承諾並編寫了一些基本的承諾,但無法使其適用於以下。
任何幫助,將不勝感激。
router.route('/salesOrders')
.get(function (req, res) {
mysql.query("QUERY", function (err, sql1) {
for (i = 0; i < sql1.length; i++) {
json.Company.SalesOrders.SalesOrder[i] = {
"Id": sql1[i].Id,
"AccountReference": sql1[i].AccountReference,
"SalesOrderDate": sql1[i].SalesOrderDate,
"SalesOrderAddress": [{
"Forename": sql1[i].billFirstname,
"Lastname": sql1[i].billLastName,
"Address": sql1[i].billAddress1
}],
"SalesOrderItems": {}
};
json.Company.SalesOrders.SalesOrder[i].SalesOrderItems = getOrderLines(sql1[i].Id);
} // End first For loop.
res.json(json);
};
};
getOrderLines = function (orderId) {
var orderLineJson = {
"Item": []
};
mysql.query('QUERY', function (err, sql2) {
for (j = 0; j < sql2.length; j++) {
orderLineJson.Item[j] = {
"SKU": sql2[j].name,
"QtyOrdered": sql2[j].quantity,
"UnitPrice": sql2[j].price
};
}
});
return orderLineJson;
};