Koa.js - फॉर्म डेटा

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

$ npm install --save koa-body

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

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

हम यहां जो नई चीजें कर रहे हैं, वह शरीर के पार्सर और मल्टर का आयात कर रही है। हम पार्सिंग जोंस और x-www-form-urlencoded हैडर अनुरोधों को पार्स करने के लिए बॉडी पार्सर का उपयोग कर रहे हैं, जबकि हम मल्टीपार्ट / फॉर्म-डेटा पार्स करने के लिए मुलर का उपयोग करते हैं।

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

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

अपना सर्वर चलाएं -

nodemon index.js

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

अपने कंसोल पर एक नज़र डालें, यह आपको जावास्क्रिप्ट ऑब्जेक्ट के रूप में आपके अनुरोध का निकाय दिखाएगा। उदाहरण के लिए -

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

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