我正在尝试拨打Extranet,这应该返回一个参数,但api不会等待它。
Orders.prototype.add = function (data, db, callback, logger) {
var extranet = new API_EXTRANET();
extranet.addOrder(data, function(err, orders) {
if (!err) {
if(callback) callback(false, orders);
}else{
if(callback) callback(err, false);
}
}, logger);
};
我试图返回一个Promise,但是什么也没发生。
Orders.prototype.add = function (data, db, callback, logger) {
var extranet = new API_EXTRANET();
return new Promise((resolve, reject) => {
extranet.addOrder(data, function(err, orders) {
if (err){
reject(err)
} else {
resolve(orders)
}
})
})
};
在这里我调用该方法:
order.addStoreOrder(order_data_update, db).then((response) => {
order.add(array_data, db, function (err, order_response) {
答案 0 :(得分:1)
您正在混合使用不同的方式来处理异步调用:回调和Promise。您应该只遵守诺言。
// There is no need for callback here, the promise replace your callback
// Because you use of await I guess you should use it here as well
Orders.prototype.add = async (data) => {
const extranet = new API_EXTRANET();
return util.promisify(extranet.addOrder)(data);
};
// How to call it
try {
const orders = await order.add(arrayData);
} catch (err) {
// Handle the error
}
如果要包装addOrder
返回,可以执行以下操作:
Orders.prototype.add = async(data) => {
const extranet = new API_EXTRANET();
try {
const orders = await util.promisify(extranet.addOrder)(data);
console.log(orders);
return orders;
} catch (err) {
console.error(err);
throw new Error('custom error');
}
};
// How to call it
try {
const orders = await order.add(arrayData);
} catch (err) {
// Handle the error
}
说明:它将使用回调的函数转换为Promise函数