ExpressJS - Données de formulaire
Les formulaires font partie intégrante du Web. Presque tous les sites Web que nous visitons nous proposent des formulaires qui soumettent ou récupèrent des informations pour nous. Pour commencer avec les formulaires, nous allons d'abord installer le middleware body-parser (pour analyser JSON et les données encodées en URL) et multer (pour analyser les données multipart / form).
Pour installer l' analyseur corporel et le multer , accédez à votre terminal et utilisez -
npm install --save body-parser multer
Remplacez votre index.js contenu du fichier avec le code suivant -
var express = require('express');
var bodyParser = require('body-parser');
var multer = require('multer');
var upload = multer();
var app = express();
app.get('/', function(req, res){
res.render('form');
});
app.set('view engine', 'pug');
app.set('views', './views');
// for parsing application/json
app.use(bodyParser.json());
// for parsing application/xwww-
app.use(bodyParser.urlencoded({ extended: true }));
//form-urlencoded
// for parsing multipart/form-data
app.use(upload.array());
app.use(express.static('public'));
app.post('/', function(req, res){
console.log(req.body);
res.send("recieved your request!");
});
app.listen(3000);
Après avoir importé l'analyseur corporel et le multer, nous utiliserons le body-parser pour analyser les demandes d'en-tête json et x-www-form-urlencoded, alors que nous utiliserons multer pour analyser les données multipart / form-data.
Créons un formulaire html pour tester cela. Créez une nouvelle vue appeléeform.pug avec le code suivant -
html
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 = "Express forms")
br
button(type = "submit") Send my greetings
Exécutez votre serveur en utilisant ce qui suit.
nodemon index.js
Maintenant, allez sur localhost: 3000 / et remplissez le formulaire comme vous le souhaitez, puis soumettez-le. La réponse suivante sera affichée -
Jetez un œil à votre console; il vous montrera le corps de votre requête en tant qu'objet JavaScript comme dans la capture d'écran suivante -
le req.bodyobject contient votre corps de requête analysé. Pour utiliser les champs de cet objet, utilisez-les simplement comme des objets JS normaux.
C'est la manière la plus recommandée d'envoyer une demande. Il existe de nombreuses autres façons, mais celles-ci ne sont pas pertinentes à couvrir ici, car notre application Express 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.