gpt4 book ai didi

javascript - Node.js 处理异步

转载 作者:行者123 更新时间:2023-11-29 11:45:55 24 4
gpt4 key购买 nike

我正在尝试了解 Node.js 的异步性质。我有一条快速路线,我知道该路线不会提供我需要的数据。本质上,第一个 mysql 查询按预期 100% 工作,并且 res.json 中返回的 json 数据是正确的。然而,在第一个 mysql 函数中,我调用另一个函数“getOrderLines()”,它总是返回“{"Item":[]}”,而不是我期望的数据。

我知道发生这种情况是因为 Node 的异步性质,但是我似乎无法解决这个问题,我研究了 promise 并编写了一些基本 promise ,但无法让它在下面工作。

如有任何帮助,我们将不胜感激。

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;
};

最佳答案

处理异步操作时不能使用return。我建议学习并实践 Promise。一开始它们有点难以理解,但一旦你明白了,我想你会更喜欢它们而不是连续传递,你可以从那里开始。

现在,您需要学习使用回调。 Promise 仍然使用回调。将回调传递给异步函数并在其异步操作完成时调用它:

function getOrderLines(orderId, cb) {
mysql.query('QUERY', function (err, sql2) {
// handle err

cb(/* processed data */)
});
}

当您调用 getOrderLines 时,您可以传递该回调,这允许您使用传递给它的值:

getOrderLines(sql1[i].Id, function (err, result) {
res.json(result);
});

关于javascript - Node.js 处理异步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34951248/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com