एक्सप्रेसजेएस - अस्थायी

पग एक्सप्रेस के लिए एक अस्थायी इंजन है। HTML के साथ हमारे सर्वर कोड की अव्यवस्था को हटाने के लिए टेंपलेटिंग इंजन का उपयोग किया जाता है, मौजूदा HTML टेम्प्लेट में बेतहाशा तार को घुसाया जाता है। पग एक बहुत शक्तिशाली टेम्पलेटिंग इंजन है जिसमें विभिन्न प्रकार की विशेषताएं शामिल हैंfilters, includes, inheritance, interpolation, आदि इस पर कवर करने के लिए बहुत जमीन है।

एक्सप्रेस के साथ पग का उपयोग करने के लिए, हमें इसे स्थापित करने की आवश्यकता है,

npm install --save pug

अब पग स्थापित हो गया है, इसे अपने ऐप के लिए टेम्प्लेटिंग इंजन के रूप में सेट करें। आपdon'tइसे 'आवश्यकता' की आवश्यकता है। निम्नलिखित कोड को अपने में जोड़ेंindex.js फ़ाइल।

app.set('view engine', 'pug');
app.set('views','./views');

अब एक नई निर्देशिका बनाएं जिसे व्यू कहा जाता है। इसके अंदर एक फाइल बनाई जाती है, जिसका नाम हैfirst_view.pug, और इसमें निम्नलिखित डेटा दर्ज करें।

doctype html
html
   head
      title = "Hello Pug"
   body
      p.greetings#people Hello World!

इस पृष्ठ को चलाने के लिए, अपने ऐप में निम्न मार्ग जोड़ें -

app.get('/first_template', function(req, res){
   res.render('first_view');
});

आपको आउटपुट इस प्रकार मिलेगा - Hello World!पग इस बहुत ही सरल दिखने वाले मार्कअप को html में कनवर्ट करता है। हमें अपने टैग बंद करने की आवश्यकता नहीं है, कक्षा और आईडी कीवर्ड का उपयोग करने की आवश्यकता नहीं है, बल्कि 'का उपयोग करें।' तथा'#'उन्हें परिभाषित करने के लिए। उपरोक्त कोड पहले में परिवर्तित हो जाता है -

<!DOCTYPE html>
<html>
   <head>
      <title>Hello Pug</title>
   </head>
   
   <body>
      <p class = "greetings" id = "people">Hello World!</p>
   </body>
</html>

पग HTML मार्कअप को सरल बनाने की तुलना में बहुत अधिक करने में सक्षम है।

पग की महत्वपूर्ण विशेषताएं

आइए अब पग की कुछ महत्वपूर्ण विशेषताओं का पता लगाएं।

सरल टैग

टैग उनके इंडेंटेशन के अनुसार नेस्टेड हैं। उपरोक्त उदाहरण की तरह,<title> भीतर इंडेंट किया गया था <head>टैग, तो यह उसके अंदर था। लेकिन वो<body> टैग उसी इंडेंटेशन पर था, इसलिए यह एक भाई-बहन था <head> टैग।

हमें टैग बंद करने की आवश्यकता नहीं है, जैसे ही पग अगले टैग को समान या बाहरी इंडेंटेशन स्तर पर सामना करता है, यह हमारे लिए टैग बंद कर देता है।

किसी टैग के अंदर टेक्स्ट डालने के लिए, हमारे पास 3 तरीके हैं -

  • Space seperated

h1 Welcome to Pug
  • Piped text

div
   | To insert multiline text, 
   | You can use the pipe operator.
  • Block of text

div.
   But that gets tedious if you have a lot of text.
   You can use "." at the end of tag to denote block of text.
   To put tags inside this block, simply enter tag in a new line and 
   indent it accordingly.

टिप्पणियाँ

पग के रूप में एक ही वाक्यविन्यास का उपयोग करता है JavaScript(//)टिप्पणी बनाने के लिए। इन टिप्पणियों को html टिप्पणियों (<! - टिप्पणी ->) में बदल दिया जाता है। उदाहरण के लिए,

//This is a Pug comment

यह टिप्पणी निम्नलिखित में परिवर्तित हो जाती है।

<!--This is a Pug comment-->

गुण

विशेषताओं को परिभाषित करने के लिए, हम कोष्ठक में, अल्पविराम द्वारा अलग की गई विशेषताओं की सूची का उपयोग करते हैं। क्लास और आईडी विशेषताओं का विशेष प्रतिनिधित्व है। एक HTML कोड के लिए कोड की निम्न पंक्ति परिभाषित विशेषताओं, कक्षाओं और आईडी को कवर करती है।

div.container.column.main#division(width = "100", height = "100")

कोड की यह लाइन, निम्न में परिवर्तित हो जाती है। -

<div class = "container column main" id = "division" width = "100" height = "100"></div>

टेंपरेचर पर वैल्यूज पास करना

जब हम एक पग टेम्पलेट प्रदान करते हैं, तो हम वास्तव में इसे हमारे मार्ग हैंडलर से एक मान दे सकते हैं, जिसे हम बाद में अपने टेम्पलेट में उपयोग कर सकते हैं। निम्नलिखित के साथ एक नया मार्ग हैंडलर बनाएं।

var express = require('express');
var app = express();

app.get('/dynamic_view', function(req, res){
   res.render('dynamic', {
      name: "TutorialsPoint", 
      url:"http://www.tutorialspoint.com"
   });
});

app.listen(3000);

और व्यू डायरेक्टरी में एक नई व्यू फाइल बनाएं, जिसे कहते हैं dynamic.pug, निम्नलिखित कोड के साथ -

html
   head
      title=name
   body
      h1=name
      a(href = url) URL

ओपन लोकलहोस्ट: आपके ब्राउज़र में 3000 / डायनामिक_व्यू; आपको निम्न आउटपुट प्राप्त करने चाहिए -

हम पाठ के भीतर इन पारित चर का भी उपयोग कर सकते हैं। किसी टैग के पाठ के बीच में पारित चर डालने के लिए, हम उपयोग करते हैं#{variableName}वाक्य - विन्यास। उदाहरण के लिए, उपरोक्त उदाहरण में, यदि हम TutorialsPoint से अभिवादन करना चाहते हैं, तो हम निम्नलिखित कार्य कर सकते थे।

html
   head
      title = name
   body
      h1 Greetings from #{name}
      a(href = url) URL

मूल्यों का उपयोग करने की इस विधि को कहा जाता है interpolation। उपरोक्त कोड निम्न आउटपुट प्रदर्शित करेगा। -

सशर्त,

हम सशर्त विवरण और लूपिंग निर्माण का भी उपयोग कर सकते हैं।

निम्नलिखित पर विचार करें -

यदि कोई उपयोगकर्ता लॉग इन है, तो पृष्ठ प्रदर्शित होना चाहिए "Hi, User" और यदि नहीं, तो "Login/Sign Up"संपर्क। इसे प्राप्त करने के लिए, हम एक सरल टेम्पलेट को परिभाषित कर सकते हैं जैसे -

html
   head
      title Simple template
   body
      if(user)
         h1 Hi, #{user.name}
      else
         a(href = "/sign_up") Sign Up

जब हम अपने मार्गों का उपयोग करते हुए इसे प्रस्तुत करते हैं, तो हम निम्नलिखित कार्यक्रम में किसी वस्तु को पास कर सकते हैं -

res.render('/dynamic',{
   user: {name: "Ayush", age: "20"}
});

आपको एक संदेश प्राप्त होगा - Hi, Ayush। लेकिन अगर हम किसी भी ऑब्जेक्ट को पास नहीं करते हैं या किसी उपयोगकर्ता कुंजी के साथ पास नहीं करते हैं, तो हमें साइनअप लिंक मिलेगा।

शामिल करें और घटक

पग एक वेब पेज के लिए घटक बनाने के लिए एक बहुत ही सहज तरीका प्रदान करता है। उदाहरण के लिए, यदि आप एक समाचार वेबसाइट देखते हैं, तो लोगो और श्रेणियों के साथ शीर्ष लेख हमेशा तय होता है। इसके बजाय कि हम हर दृश्य को बनाते हैं, हम इसका उपयोग कर सकते हैंincludeसुविधा। निम्नलिखित उदाहरण से पता चलता है कि हम इस सुविधा का उपयोग कैसे कर सकते हैं -

निम्नलिखित कोड के साथ 3 विचार बनाएं -

HEADER.PUG

div.header.
   I'm the header for this website.

CONTENT.PUG

html
   head
      title Simple template
   body
      include ./header.pug
      h3 I'm the main content
      include ./footer.pug

FOOTER.PUG

div.footer.
   I'm the footer for this website.

इसके लिए एक मार्ग बनाएँ:

var express = require('express');
var app = express();

app.get('/components', function(req, res){
    res.render('content');
});

app.listen(3000);

लोकलहोस्ट पर जाएं: 3000 / घटक, आपको निम्न आउटपुट प्राप्त होंगे -

include प्लेनटेक्स्ट, सीएसएस और जावास्क्रिप्ट को शामिल करने के लिए भी इस्तेमाल किया जा सकता है।

पग की कई और विशेषताएं हैं। लेकिन वे इस ट्यूटोरियल के दायरे से बाहर हैं। आप आगे पग में पग का पता लगा सकते हैं ।