使用q

这种方式,极大的避免了回调地狱的情况产生,以后打算长久用这种方式。
再写Nodejs,再也不担心这个问题了。
以下实例,作为连接数据库的公共方法。


/**
 * Created by ThinkCat on 15/11/24.
 */
var mysql = require('./db/db');
var Q = require('q');

//var getConnection = function(){
//    var deferred = Q.defer();
//    mysql.MySqlDb.getConnection(function(err,connection){
//        console.log('connection:',connection);
//        deferred.resolve(connection);
//    });
//    return deferred.promise;
//}
//
//var doQuery = function(connection){
//    var deferred = Q.defer();
//    connection.query('select * from user',function(err,rows){
//        console.log('rows:',rows);
//        deferred.resolve(rows);
//    });
//    return deferred.promise;
//}

var getConnection = function(){
    var deferred = Q.defer();
    deferred.resolve('this is a connection');
    return deferred.promise;
};

var doQuery = function(connection){
    var deferred = Q.defer();
    deferred.resolve(connection + ',select * from user');
    return deferred.promise;
};

function main(){
    getConnection()
        .then(doQuery)
        .done(
            function(data){
                console.log('final:',data);
            },
            function(err){
                console.log('error:',err);
            }
        );
}


main();

相关文章:

  • 2021-08-04
  • 2021-07-05
  • 2021-06-12
  • 2021-08-13
  • 2022-02-02
  • 2021-05-30
猜你喜欢
  • 2022-12-23
  • 2021-07-29
  • 2022-12-23
  • 2021-07-26
  • 2021-07-16
  • 2022-02-13
  • 2021-06-23
相关资源
相似解决方案