ExpressJS - Datos de formulario

Los formularios son una parte integral de la web. Casi todos los sitios web que visitamos nos ofrecen formularios que envían o obtienen información para nosotros. Para comenzar con los formularios, primero instalaremos el body-parser (para analizar JSON y datos codificados en URL) y el middleware multer (para analizar datos de múltiples partes / formularios).

Para instalar body-parser y multer , vaya a su terminal y use -

npm install --save body-parser multer

Reemplaza tu index.js contenido de archivo con el siguiente código:

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);

Después de importar el analizador de cuerpo y el multer, usaremos el body-parser para analizar las solicitudes de encabezado json y x-www-form-urlencoded, mientras que usaremos multer para analizar multipart / form-data.

Creemos un formulario html para probar esto. Crea una nueva vista llamadaform.pug con el siguiente código -

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

Ejecute su servidor usando lo siguiente.

nodemon index.js

Ahora vaya a localhost: 3000 / y complete el formulario que desee y envíelo. Se mostrará la siguiente respuesta:

Eche un vistazo a su consola; le mostrará el cuerpo de su solicitud como un objeto JavaScript como en la siguiente captura de pantalla:

los req.bodyEl objeto contiene el cuerpo de su solicitud analizada. Para usar campos de ese objeto, utilícelos como objetos JS normales.

Esta es la forma más recomendada de enviar una solicitud. Hay muchas otras formas, pero es irrelevante cubrirlas aquí, porque nuestra aplicación Express manejará todas esas solicitudes de la misma manera. Para leer más sobre las diferentes formas de realizar una solicitud, eche un vistazo a esta página.