Async.waterfall的Native Callback函数

时间:2016-03-02 17:23:57

标签: javascript node.js asynchronous callback bluebird

我实现了一个用Node.js编写的项目并从Mysql中获取值。 当我在我的项目中深入了解我的嵌套回调

hold.getEntry(function(data){
    var ref = data.ref;
    var id = data.id;
    var message = data.mess;
    var json = JSON.parse(message);

    if(ref === null){
    } else {
        hold.checkPositionCandidate(ref, id, json, function(dataa){
            console.log("checker " + dataa);
            if(dataa == false){
            } else {
                //\/ here I get error callback is not a function
                hold.getVoterCount(id, json, function(votercount){
                    if(votercount.count == 0){
                    } else {
                        checkVoter(ref, votercount.count, function(isallcorrect){
                            if(isallcorrect == false){
                                console.log('mali votes');
                            } else {
                                console.log('tama votes');
                            }
                        })
                    }
                });
            }

        });
    }
});

我得到"回调不是一个功能"。我研究过并发现了回调地狱'所以我找到了替代方案并使用Async.js

现在我的问题是如何将此代码转换为async.waterfall ??? 有人可以帮我弄这个吗???? pleaseeee。

更新1

我已经实现了Peteb的答案,但是当我执行它时,执行第一个函数。这是新代码。

var id = "";
var json = "";

async.waterfall([
    function (callback) {
        // hold.checkPositionCandidate
        // if err return callback(err, null)
        // if successful return callback(null, dataa)
        hold.getEntry(function(data){
            var ref = data.ref;
            id = data.id;
            var message = data.mess;
            json = JSON.parse(message);

            callback({'ref':ref, 'id':id, 'json':json});
        console.log(data);
        });
    },
    function (dataa, callback) {
        // hold.getVoterCount
        // if err return callback(err, null)
        // if successful return callback(null, votercount)
        if(dataa.ref === null){
            callback(null);
        }else{
            hold.checkPositionCandidate(dataa.ref, dataa.id, dataa.json, function(dataaa){
                callback(dataaa);
            });
        }
        console.log('gfh');
    },
    function(anoData, callback) {
        // checkVoter
        // if err return callback(err, null)
        // if successful return callback()
        if(anoData === false){
        } else {
            hold.getVoterCount(id, json, function(votercount){
                if(votercount == 0){
                } else {
                    console.log('last function');
                }
            });
        }
    }
], function (err, results) {
   // When finished execute this
});

1 个答案:

答案 0 :(得分:2)

async.waterfall展平嵌套回调,并使用单个error-first callback将结果从一个函数传递到下一个函数。因此,回调链中的每个步骤都将按照需要执行的顺序表示您的瀑布函数。

async.waterfall([
  function (callback) {
    // hold.checkPositionCandidate
    // if err return callback(err, null)
    // if successful return callback(null, dataa)
  }),
  function (dataa, callback) {
    // hold.getVoterCount
    // if err return callback(err, null)
    // if successful return callback(null, votercount)
  }),
  function(votercount, callback) {
    // checkVoter
    // if err return callback(err, null)
    // if successful return callback()
  })
], function (err, results) {
   // When finished execute this
});

编辑:更新了解决更新问题的答案。

callback({'ref':ref, 'id':id, 'json':json}); // this is wrong

async.waterfall()期待您的回调的第一个参数为Errornull。需要传递的任何值都在Error参数之后。

// this is correct
return callback(null, { ref: ref, id: id, json: json }); 

// this is also correct
return callback(null, ref, id, json); 

示例hold.getEntry()

hold.getEntry(function(data){
  var ref = data.ref; 
  id = data.id;
  var message = data.mess;
  json = JSON.parse(message);

  return callback(null, {ref: ref, id: id, json: json});
});