Koa.js - Construction d'URL

Nous pouvons maintenant définir des itinéraires; ils sont statiques ou fixes. Pour utiliser des routes dynamiques, nous devons fournir différents types de routes. L'utilisation de routes dynamiques nous permet de passer des paramètres et de traiter en fonction de ceux-ci. Voici un exemple d'itinéraire dynamique.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/:id', sendID);

function *sendID() {
   this.body = 'The id you specified is ' + this.params.id;
}

app.use(_.routes());
app.listen(3000);

Pour tester cela, allez à https://localhost:3000/123. Vous obtiendrez la réponse suivante.

Vous pouvez remplacer "123" dans l'URL par autre chose et cela sera reflété dans la réponse. Voici un exemple complexe de ce qui précède.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/things/:name/:id', sendIdAndName);

function *sendIdAndName(){
   this.body = 'id: ' + this.params.id + ' and name: ' + this.params.name;
};

app.use(_.routes());

app.listen(3000);

Pour tester cela, allez à https://localhost:3000/things/tutorialspoint/12345.

Vous pouvez utiliser le this.paramsobject pour accéder à tous les paramètres que vous passez dans l'URL. Notez que les deux ci-dessus ont des chemins différents. Ils ne se chevaucheront jamais. De plus, si vous souhaitez exécuter le code lorsque vous obtenez '/ things', vous devez le définir séparément.

Itinéraires avec correspondance de modèle

Vous pouvez également utiliser regex pour restreindre la correspondance des paramètres d'URL. Supposons que vous ayez besoin que l'identifiant soit composé de cinq chiffres. Vous pouvez utiliser la définition d'itinéraire suivante.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/things/:id([0-9]{5})', sendID);

function *sendID(){
   this.body = 'id: ' + this.params.id;
}

app.use(_.routes());
app.listen(3000);

Notez que cela va onlycorrespondent aux demandes qui ont un identifiant long à 5 chiffres. Vous pouvez utiliser des expressions régulières plus complexes pour faire correspondre / valider vos itinéraires. Si aucun de vos itinéraires ne correspond à la demande, vous recevrez un message Not found en réponse.

Par exemple, si nous définissons les mêmes routes que ci-dessus, sur demande avec une URL valide, nous obtenons -