Koa.js - Générateurs

L'une des nouvelles fonctionnalités les plus intéressantes de JavaScript ES6 est une nouvelle génération de fonctions, appelée générateur. Avant les générateurs, l'ensemble du script était généralement utilisé pour s'exécuter de haut en bas, sans moyen simple d'arrêter l'exécution du code et de reprendre plus tard avec la même pile. Les générateurs sont des fonctions qui peuvent être quittées et réintroduites ultérieurement. Leur contexte (liaisons variables) sera sauvegardé à travers les rentrées.

Les générateurs nous permettent d'arrêter l'exécution du code entre les deux. Jetons donc un coup d'œil à un générateur simple.

var generator_func = function* (){
   yield 1;
   yield 2;
};

var itr = generator_func();
console.log(itr.next());
console.log(itr.next());
console.log(itr.next());

Lors de l'exécution du code ci-dessus, le résultat sera le suivant.

{ value: 1, done: false }
{ value: 2, done: false }
{ value: undefined, done: true }

Regardons à l'intérieur du code ci-dessus. Nous créons d'abord un générateur appelégenerator_func(). Nous avons créé une instance de cette fonction étrange et l'avons assignée àitr. Puis nous avons commencé à appelernext() sur cette variable itr.

L'appel de next () démarre le générateur et il s'exécute jusqu'à ce qu'il atteigne un rendement. Ensuite, il renvoie l'objet avec valeur et terminé, où la valeur a la valeur d'expression. Cette expression peut être n'importe quoi. À ce stade, il interrompt l'exécution. Encore une fois, lorsque nous appelons cette fonction (next), le générateur reprend l'exécution à partir du dernier seuil d'élasticité, l'état de la fonction étant le même au moment de la pause, jusqu'au prochain seuil d'élasticité. Ceci est fait jusqu'à ce qu'il n'y ait plus de points de rendement dans le code.

Générateurs à Koa

Alors, pourquoi parlons-nous des générateurs dans ce didacticiel. Comme vous vous en souvenez peut-être dans le programme hello world, nous avons utilisé unfunction* ()notation pour passer un rappel à app.use (). Koa est un objet, qui contient un tableau de fonctions génératrices de middleware, qui sont toutes composées et exécutées à la manière d'une pile à chaque requête. Koa met également en œuvre l'aval suivi de l'amont du flux de contrôle.

Jetez un œil à l'exemple suivant pour mieux comprendre cela.

var koa = require('koa');
var app = koa();
 
app.use(function* (next) {
   //do something before yielding to next generator function 
   
   //in line which will be 1st event in downstream
   console.log("1");
   yield next;
 
   //do something when the execution returns upstream, 
   //this will be last event in upstream
   console.log("2");
});
app.use(function* (next) {
   // This shall be 2nd event downstream
   console.log("3");
   yield next;
 
   // This would be 2nd event upstream
   console.log("4");
});
app.use(function* () { 
   // Here it would be last function downstream
   console.log("5");
   
   // Set response body
   this.body = "Hello Generators";

   // First event of upstream (from the last to first)
   console.log("6");
});

app.listen(3000);

Lors de l'exécution du code ci-dessus et de la navigation vers https://localhost:3000/ nous obtenons la sortie suivante sur notre console.

1
3
5
6
4
2

C'est essentiellement ainsi que Koa utilise les générateurs. Cela nous permet de créer un middleware compact en utilisant cette propriété et d'écrire du code pour les fonctionnalités en amont et en aval, nous évitant ainsi des rappels.