[英]NodeJs - async function javascript
我正在 NodeJs 中制作一個 api,我有一個通過帖子調用的函數,但在轉發到精確存儲庫之前,我運行函數getProduct (idProd, product)
,但正在執行console.log ('product ->' + product.name);
在運行getProduct (idProd, product)
函數之前。 我不知道如何讓它等待其他功能完成。 我已經嘗試添加async和await ,但沒有成功
exports.postItemProduto = async function (req, res) {
try {
var idProd = req.body.produtoPrincipal;
await getProduto(idProd, produto);
console.log('produto -> '+ produto.nome);
itemService.insertItem(req, function (err) {
if (err) {
return res.status(412).send({
success: false
});
}
return res.send({
success: true,
message: 'Item registado com sucesso!'
});
})
} catch (err) {
console.log(err);
return res.status(400).send({
error: 'Erro criar item'
});
};
};
function getProduto(id, produto){
var url = 'url/api/produtos/'+id;
axios
.get(url)
.then(response => {
/* let produto = new ProductDto(); */
produto.produtoId = response.data.productId;
produto.nome = response.data.nome;
produto.descricao = response.data.descricao;
produto.material_AcabamentoID = response.data.material_AcabamentoID;
produto.restrictionId = response.data.restrictionId;
/* let restriction = new RestrictionDto();
restriction = getRestriction(jsonData[i].restrictionId); */
console.log('produto -->' + produto.nome);
}).catch(error => {
console.log(error);
});
}
exports.postItemProduto = function (req, res) {
try {
var idProd = req.body.produtoPrincipal;
console.log('id --> ' + idProd);
getProduto(idProd, function(produto) {
console.log('produto -> ' + produto.nome);
});
itemService.insertItem(req, function (err) {
if (err) {
return res.status(412).send({
success: false
});
}
return res.send({
success: true,
message: 'Item registado com sucesso!'
});
})
} catch (err) {
console.log(err);
return res.status(400).send({
error: 'Erro criar item'
});
};
};
function getProduto(id, callback) {
var url = 'url/api/produtos/' + id;
axios
.get(url)
.then(response => {
/* let produto = new ProductDto(); */
produto.produtoId = response.data.productId;
produto.nome = response.data.nome;
produto.descricao = response.data.descricao;
produto.material_AcabamentoID = response.data.material_AcabamentoID;
produto.restrictionId = response.data.restrictionId;
/* let restriction = new RestrictionDto();
restriction = getRestriction(jsonData[i].restrictionId); */
callback(produto);
}).catch(error => {
console.log(error);
});
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.