nodejs的问题Promise序列

时间:2017-09-21 18:57:17

标签: javascript node.js

嗨,在下面的功能中,当我打印日志文件时,我可以看到按以下顺序显示的消息,虽然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;
}

2 个答案:

答案 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
});