嗨,在下面的功能中,当我打印日志文件时,我可以看到按以下顺序显示的消息,虽然promise用于同步通信。
显示序列 -
a)“来电前” b“通话后” c)“内部保存” d)“没有问题”
我在代码中如何更改以获取日志顺序,如下所示 -
a)“来电前” b)“通话后” c)“没有问题” d)“内部保存”
控制器代码 -
module.exports.updateLocalTransportVendorDtls = function (req, res) {
var transportSchema = new transportModel();
new Promise(function (resolve, reject) {
checkForNewVehicleType(req, function (doc) {
resolve(doc)
})
})
.then(function (doc) {
var updateJustServiceDtls = doc.split(/\|/)[2];
var updateVehicle = doc.split(/\|/)[0];
var addVehicle = doc.split(/\|/)[1];
if (updateJustServiceDtls == 'true') { /* To update service details for the same vendor */
console.log("before call")
updateJustServiceDetailsOnly(req, res)
console.log("after call")
}
}).then(function () {
console.log("inside save")
transportSchema.save(function (error) {
if (error) {
return res.status(500).json({ "Message": error.message.trim() });
}
else {
return res.json({ "Message": "Data got inserted successfully in local_transport_details collection" });
}
})
}).catch(function (err) {
return res.json({ "Message": err.message });
});
}
函数调用 -
var updateJustServiceDetailsOnly = function (req, res) {
var promise = new Promise(function (resolve, reject) {
//code to update db
console.log("no issues")
resolve();
});
})
return promise;
}
答案 0 :(得分:0)
after call
怎么办?如果它只是log并且返回updateJustServiceDetailsOnly
的结果,你可以省略它。
返回将强制将执行传递给下一个,然后updateJustServiceDetailsOnly
的承诺将被解决。但在该行之后,没有代码可以工作。如果您需要所需的结果,则需要在返回后删除该部件。
if (updateJustServiceDtls == 'true') {
console.log("before call")
return updateJustServiceDetailsOnly(req, res)
// console.log("after call") this will not be called
}
使用此代码,结果将是
a)"before call" b)"no issues" c)"inside save"
答案 1 :(得分:0)
回报你的承诺。
if (updateJustServiceDtls == 'true') { /* To update service details for the same vendor */
console.log("before call")
return updateJustServiceDetailsOnly(req, res)
console.log("after call")
}
在这种情况下,显然在通话后不会被记录。但只需在下一个.then
中移动日志即可。
当你在Promise链中时,如果你有另一个Promise要做,你想等待它,那就回去吧。
示例:
Promise.resolve()
.then(() => {
// I have an async to do, I return it to wait for it
return Promise.resolve('after call');
})
.then((result) => {
// it will be called only when the Promise returned in the previous chain will resolve
// the result is the data passed in the resolution of your promise
console.log(result); // after call
});