从节点 js 异步函数进行多次回调

Make multiple callbacks from node js asynchronous function

本文关键字:回调 函数 节点 js 异步      更新时间:2023-09-26

如何返回异步函数从异步函数中多次调用返回的数据对象。

我正在尝试像这样实现:

var figlet = require('figlet');
function art(dataToArt, callback)
{ 
var arry[];
    figlet(dataToArt, function(err, data) { 
        if (err) { 
            console.log('Something went wrong...'); 
            console.dir(err); 
            return callback(''); 
        } 
    arry[0] = data;
        callback(arry);
    });

figlet(dataToArt, function(err, data) { 
        if (err) { 
            console.log('Something went wrong...'); 
            console.dir(err); 
            return callback(''); 
        } 
    arry[1] = data;
        callback(arry);
    });
} 

art('Hello World', function (data){
    console.log(data);
});

怎样才能正确地做到这一点,我搜索了又搜索,但找不到解决方案。

附言。我正在使用无花果.js

我不知道

你是否可以使用外部模块,但你可以使用脚尖。

像任何常规模块一样使用npm install tiptoe安装它,它基本上是这样的:

var tiptoe = require('tiptoe')
function someAsyncFunction(obj, callback) {
  // something something
  callback(null, processedData);
}
tiptoe(
  function() {
    var self = this;
    var arr = ['there', 'are', 'some', 'items', 'here'];
    arr.forEach(function(item) {
      someAsyncFunction(item, self.parallel());
    });
  },
  function() {
    var data = Array.prototype.slice.call(arguments);
    doSomethingWithData(data, this);
  },
  function(err) {
    if (err) throw (err);
    console.log('all done.');
  }
);

someAsyncFunction()是您要调用的异步函数执行某些操作,并将callback参数作为具有参数的函数调用 errordatadata 参数将作为数组项传递给tiptoe流上的以下函数。

自己做了:)感谢穆斯塔法-萨米尔的帖子

var figlet = require('figlet');
function WaterfallOver(list, iterator, callback) {
    var nextItemIndex = 1;
    function report() {
        nextItemIndex++;
        if(nextItemIndex === list.length)
            callback();
        else
            iterator([list[0],list[nextItemIndex]], report);
    }
    iterator([list[0],list[1]], report);
}
var FinalResult = [];
WaterfallOver(["hello","Standard","Ghost"], function(path, report) {
    figlet.text(path[0], { font: path[1]  }, function(err, data) {
      if (err) {
          FinalResult.push("Font name error try help");
          report();
          return;
      }
      data = '<pre>.'n' + data + '</pre>';
      FinalResult.push(data);
      report();
  });
}, function() {
    console.log(FinalResult[0]);
    console.log(FinalResult[1]);
});