Koa.js - Données de formulaire

Les formulaires font partie intégrante du Web. Presque tous les sites Web que nous visitons nous offrent des formulaires qui soumettent ou récupèrent des informations pour nous. Pour commencer avec les formulaires, nous allons d'abord installer le koa-body. Pour l'installer, allez sur votre terminal et utilisez -

$ npm install --save koa-body

Remplacez le contenu de votre fichier app.js par le code suivant.

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

//Set up Pug
var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

//Set up body parsing middleware
app.use(bodyParser({
   formidable:{uploadDir: './uploads'},
   multipart: true,
   urlencoded: true
}));

_.get('/', renderForm);
_.post('/', handleForm);

function * renderForm(){
   this.render('form');
}
function *handleForm(){
   console.log(this.request.body);
   console.log(this.req.body);
   this.body = this.request.body; //This is where the parsed request is stored
}

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

Les nouvelles choses que nous faisons ici sont l'importation de l'analyseur corporel et du multer. Nous utilisons l'analyseur de corps pour analyser les demandes d'en-tête json et x-www-form-urlencoded, tandis que nous utilisons multer pour analyser multipart / form-data.

Créons un formulaire html pour tester cela! Créez une nouvelle vue nommée form.pug avec le code suivant.

html
   head
      title Form Tester
   body
      form(action = "/", method = "POST")
         div
            label(for = "say") Say: 
            input(name = "say" value = "Hi")
         br
         div
            label(for = "to") To: 
            input(name = "to" value = "Koa form")
         br
         button(type = "submit") Send my greetings

Exécutez votre serveur en utilisant -

nodemon index.js

Maintenant, allez sur localhost: 3000 / et remplissez le formulaire comme vous le souhaitez, puis soumettez-le. Vous recevrez la réponse comme -

Jetez un œil à votre console, elle vous montrera le corps de votre requête en tant qu'objet JavaScript. Par exemple -

le this.request.bodyobject contient votre corps de requête analysé. Pour utiliser les champs de cet objet, utilisez-les simplement comme des objets JS normaux.

Ce n'est qu'une façon d'envoyer une demande. Il existe de nombreuses autres façons, mais celles-ci ne sont pas pertinentes à couvrir ici, car notre application Koa traitera toutes ces demandes de la même manière. Pour en savoir plus sur les différentes façons de faire une demande, consultez cette page.