<p>async.waterfall se casse lorsqu'on lui donne une fonction async (nœud 8)</p>

Créé le 5 oct. 2017  ·  8Commentaires  ·  Source: caolan/async

Quelle version d'async utilises-tu ?
2.5.0

Dans quel environnement le problème s'est-il produit (version du nœud/version du navigateur)
Nœud 8

Qu'est-ce que tu as fait?

async=require('async')

async function myFirstFunction(callback) {
     callback(null, 'one', 'two');
}

function mySecondFunction(arg1, arg2, callback) {
     // arg1 now equals 'one' and arg2 now equals 'two'
     callback(null, 'three');
}

async function myLastFunction(arg1, callback) {
     // arg1 now equals 'three'
     callback(null, 'done');
}

async.waterfall([
     myFirstFunction,
     mySecondFunction,
     myLastFunction,
], function (err, result) {
     // result now equals 'done'
     console.log(err, result)
});

Que vous attendiez-vous à ce qu'il se passe ?
ne pas avoir d'exception

Quel a été le résultat réel ?

> TypeError: callback is not a function
    at myFirstFunction (repl:2:5)
    at /Users/scott/node_modules/async/dist/async.js:143:27
    at /Users/scott/node_modules/async/dist/async.js:21:12
    at nextTask (/Users/scott/node_modules/async/dist/async.js:5297:14)
    at Object.waterfall (/Users/scott/node_modules/async/dist/async.js:5307:5)
    at repl:1:7
    at ContextifyScript.Script.runInThisContext (vm.js:44:33)
    at REPLServer.defaultEval (repl.js:239:29)
    at bound (domain.js:301:14)
    at REPLServer.runBound [as eval] (domain.js:314:12) undefined
docs question

Commentaire le plus utile

Oui, tu peux faire quelque chose comme :

async.waterfall([
  // ...
  async function (arg1, arg2) {
    //...
    const arg3 = await foo()
    return [arg1, arg2, arg3]
  },
  function ([arg1, arg2, arg3], callback) {
    //...
  }

Tous les 8 commentaires

Les rappels ne sont pas transmis aux fonctions async , mais renvoient simplement une valeur.

Dans le cas de la première fonction ci-dessus, où plusieurs arguments sont passés à callback dans myFirstFunction , devrions-nous plutôt retourner un tableau ?

Oui, tu peux faire quelque chose comme :

async.waterfall([
  // ...
  async function (arg1, arg2) {
    //...
    const arg3 = await foo()
    return [arg1, arg2, arg3]
  },
  function ([arg1, arg2, arg3], callback) {
    //...
  }

Alors comment retourner l'erreur? Juste en utilisant jeter?

Des réponses à la question ci-dessus ? Je pense que pour renflouer en cas d'erreur dans une fonction asynchrone, vous devez toujours appeler le rappel "suivant"

Que dis-tu de ça?

async.waterfall([
  // ...
  async function (arg1, arg2, callback) {
    //...
    try {
      const arg3 = await foo()
      return [arg1, arg2, arg3]
    } catch (err) {
      callback('An error occured:' + err.message);
    }
  },
  function ([arg1, arg2, arg3], callback) {
    //...
  }

async ne reçoivent pas de rappels. Juste throw une erreur.

Merci.

Cette page vous a été utile?
0 / 5 - 0 notes