与mongo db的异步瀑布

时间:2015-10-21 06:51:17

标签: node.js mongodb asynchronous monk

可能只是异步的基本概念。我想检查一下我们如何将数组变量从mongo result(docs)传递给第二个函数。在下面的代码中,第二个console.log不提供任何输出。

// Retrieve
var db = require('monk')('localhost/db');
var async = require('async');

console.log('start');

async.waterfall([

    function(callback) {
        var test = db.get('test');
        test.find({}, function(err, docs) {
            console.log(docs);  //OUTPUT OK
            callback(docs);  

        });

    },
    function(docs, callback) {
        console.log(docs);  //NO OUTPUT
    }
])

2 个答案:

答案 0 :(得分:5)

为了让您更好地了解使用 async 模块使用多个回调,让我们通过 Seven Things You Should Stop Doing with Node.js 的示例来说明这一点。具有回调的多个操作以查找父实体,然后查找属于父实体的子实体:

methodA(function(a){
    methodB(function(b){
        methodC(function(c){
            methodD(function(d){
                // Final callback code        
            })
        })
    })
})

使用async模块,您可以使用系列方法来解决使用回调来嵌套多个方法的代码,这可能会导致 Callback Hell

<强>系列

async.series([
    function(callback){
        // code a
        callback(null, 'a')
    },
    function(callback){
        // code b
        callback(null, 'b')
    },
    function(callback){
        // code c
        callback(null, 'c')
    },
    function(callback){
        // code d
        callback(null, 'd')
    }],
    // optional callback
    function(err, results){
        // results is ['a', 'b', 'c', 'd']
        // final callback code
    }
)

瀑布

async.waterfall([
    function(callback){
        // code a
        callback(null, 'a', 'b')
    },
    function(arg1, arg2, callback){
        // arg1 is equals 'a' and arg2 is 'b'
        // Code c
        callback(null, 'c')
    },
    function(arg1, callback){      
        // arg1 is 'c'
        // code d
        callback(null, 'd');
    }], function (err, result) {
        // result is 'd'    
    }
)

现在回到您的示例,使用异步瀑布方法,您可以将代码重组为

async.waterfall([
    function(callback) {
        // code a
        var test = db.get('test');
        test.find({}, function(err, docs) {
            if(err) callback(err);

            console.log(docs);  // OUTPUT OK
            callback(null, docs);                                    
        });
    }], function(err, result) {
        if(err) callback(err);
        console.log(result);  // OUTPUT OK
    }
])

答案 1 :(得分:1)

您必须始终处理错误。试试这个!

// Retrieve
var db = require('monk')('localhost/db');
var async = require('async');

console.log('start');

async.waterfall([

    function(callback) {
        var test = db.get('test');
        test.find({}, function(err, docs) {
            if(err){
                console.log(err);
                callback(err);
            }
            else if(docs){
                console.log(docs);
                callback(null,docs);
            }
            else{
                console.log("No error no docs");
                callback(null);
            }

        });

    },
    function(err, docs) {
        if(err)
           console.log(err);
        else{
           console.log(docs);
        }
    }
])