एक्सप्रेसजेएस - फॉर्म डेटा

प्रपत्र वेब का एक अभिन्न अंग हैं। हमारे द्वारा देखी जाने वाली लगभग हर वेबसाइट हमें ऐसे फ़ॉर्म प्रदान करती है जो हमारे लिए कुछ जानकारी जमा करते हैं या लाते हैं। प्रपत्रों के साथ आरंभ करने के लिए, हम पहले बॉडी-पार्सर (जेंसन और यूआरएल-एन्कोडेड डेटा पार्स करने के लिए) और मल्टर (मल्टीपार्ट / फॉर्म डेटा पार्स करने के लिए) मिडलवेयर स्थापित करेंगे।

बॉडी-पार्सर और मल्टर को स्थापित करने के लिए , अपने टर्मिनल पर जाएं और उपयोग करें -

npm install --save body-parser multer

अपने को बदलें index.js निम्नलिखित कोड के साथ फ़ाइल सामग्री -

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

शरीर पार्सर और मल्टर आयात करने के बाद, हम इसका उपयोग करेंगे body-parser जर्सन और एक्स-www-फॉर्म-यूरलेंकोडेड हेडर अनुरोधों के लिए, जबकि हम उपयोग करेंगे multer मल्टीपार्ट / फॉर्म-डेटा पार्स करने के लिए।

आइए हम इसका परीक्षण करने के लिए एक HTML फॉर्म बनाते हैं। नामक एक नया दृश्य बनाएँform.pug निम्नलिखित कोड के साथ -

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

निम्नलिखित का उपयोग करके अपना सर्वर चलाएं।

nodemon index.js

अब लोकलहोस्ट पर जाएं: 3000 / और जैसा चाहें वैसा फॉर्म भरें और सबमिट करें। निम्नलिखित प्रतिक्रिया प्रदर्शित की जाएगी -

अपने कंसोल पर एक नज़र रखना; यह आपको निम्नलिखित स्क्रीनशॉट में जावास्क्रिप्ट ऑब्जेक्ट के रूप में आपके अनुरोध का मुख्य भाग दिखाएगा -

req.bodyऑब्जेक्ट में आपका पार्स किया गया अनुरोध निकाय है। उस ऑब्जेक्ट से फ़ील्ड का उपयोग करने के लिए, उन्हें सामान्य JS ऑब्जेक्ट्स की तरह उपयोग करें।

अनुरोध भेजने के लिए यह सबसे अनुशंसित तरीका है। कई अन्य तरीके हैं, लेकिन वे यहां कवर करने के लिए अप्रासंगिक हैं, क्योंकि हमारा एक्सप्रेस ऐप उसी तरह से उन सभी अनुरोधों को संभाल लेगा। अनुरोध करने के विभिन्न तरीकों के बारे में अधिक पढ़ने के लिए, इस पृष्ठ पर एक नज़र डालें ।