Javascript Async.瀑布的本机回调函数

Javascript Async.瀑布的本机回调函数,javascript,node.js,asynchronous,callback,bluebird,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.check

我正在实现一个用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.瀑布??? 有人能帮我吗????请

更新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
});

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

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

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

回调({'ref':ref'id':id'json':json});//这是错误的

期望回调的第一个参数为
错误
。任何需要传递的值,在
错误
参数之后进行

// 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});
});

谢谢你的回复。我会给你一个例子的更新。我在我的项目中应用了你的示例,但它只执行第一个函数。你需要用这些函数的实际逻辑替换我的注释,并在执行完成后调用回调函数,以便调用下一个函数。是的,我已经这样做了,先生。顺便说一句,我发布了我的改进版codes@something您没有正确实现回调。您需要使用错误优先回调。这就是async构造回调的方式,就像在节点中执行大多数操作一样。