我试图让我的头绕着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;
};