Nodejs学习笔记(四)

Nodejs用async来处理异步问题:

今天在写mysql数据库操作的时候,发现当我要查询多条sql语句的时候 前一条的语句在后一条语句执行完的时候还没有完成,这个导致很多语句的返回值都是undefined
var subItems;
connection.query($sql, [userID], function (err, result) {
    req.session.subItems = result;
    subItems = result;
    console.log(subItems);//上面这条能输出准确的结果 在后面执行
}
    console.log(subItems);//这条语句会比上一条先执行 所有导致这条语句的结果是undefined

采用aysnc就能够使上面的代码按照循序执行
async.series([  //第一个参数是一个函数数组
    function (cb) {
        connection.query($sql, [userID], function (err, result) {
            req.session.subItems = result;
            subItems = result;
            cb(err,result)  //把异常跟结果回调
        });

    },function (cb) {
        cb(err,user);
    }
],function (err,results) {  //第二个参数function是回调函数  results是一个结果数组  
    if(err){
        console.log(err)

    }else {
        console.log(results);
    }
});

async里有很多的方法 我这个是其中一个比较简单 比较通用的方法



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值