प्रोटोटाइप - अस्थायी

टेम्पलेट का उपयोग समान वस्तुओं के समूह को प्रारूपित करने और इन वस्तुओं के लिए स्वरूपित आउटपुट के लिए किया जाता है।

प्रोटोटाइप एक खाका वर्ग प्रदान करता है , जिसके दो तरीके हैं -

  • Template()- यह एक कंस्ट्रक्टर विधि है, जिसका उपयोग टेम्प्लेट ऑब्जेक्ट बनाने के लिए और टेम्प्लेट लगाने के लिए कॉल असेसमेंट () विधि के लिए किया जाता है।

  • evaluate() - इस विधि का उपयोग किसी वस्तु को प्रारूपित करने के लिए टेम्पलेट लगाने के लिए किया जाता है।

स्वरूपित आउटपुट बनाने के लिए तीन चरण शामिल हैं।

  • Create a template- इसमें पूर्वनिर्मित टेक्स्ट बनाना शामिल है। इस पाठ में स्वरूपित सामग्री के साथ है#{fieldName}मान। इन#{fieldName}मूल्यों को वास्तविक मूल्यों से बदल दिया जाएगा जब मूल्यांकन () विधि को वास्तविक मूल्यों के साथ कहा जाएगा।

  • Defining actual values- इसमें कुंजी और मान के रूप में वास्तविक मूल्य बनाना शामिल है। इन कीज़ को टेम्प्लेट में मैप किया जाएगा और उन्हें संबंधित मानों से बदल दिया जाएगा।

  • Mapping Keys and replacing Values- यह अंतिम चरण है जहां मूल्यांकन () कहा जाएगा और प्रारूपित वस्तु में उपलब्ध सभी कुंजियों को परिभाषित मूल्यों से बदल दिया जाएगा।

उदाहरण 1

चरण 1

एक टेम्पलेट बनाएँ।

var myTemplate = new Template('The \ TV show #{title} was directed by #{author}.');

चरण 2

मानों के हमारे सेट को तैयार करें, जो कि उपर्युक्त ऑब्जेक्ट में एक स्वरूपित आउटपुट के लिए पारित किया जाएगा।

var record1 = {title: 'Metrix', author:'Arun Pandey'};
var record2 = {title: 'Junoon', author:'Manusha'};
var record3 = {title: 'Red Moon', author:'Paul, John'};
var record4 = {title: 'Henai', author:'Robert'};
var records = [record1, record2, record3, record4 ];

चरण 3

अंतिम चरण टेम्पलेट में सभी मूल्यों को भर रहा है और अंतिम परिणाम का उत्पादन निम्नानुसार है -

records.each( function(conv) {
   alert( "Formatted Output : " + myTemplate.evaluate(conv) );
});

तो, आइए इन तीनों चरणों को एक साथ रखें -

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         function showResult() {
            //  Create template with formatted content and placeholders.
            var myTemplate = new Template('The \ TV show #{title} was directed by #{author}.');
   
            // Create hashes with the required values for placeholders
            var record1 = {title: 'Metrix', author:'Arun Pandey'};
            var record2 = {title: 'Junoon', author:'Manusha'};
            var record3 = {title: 'Red Moon', author:'Paul, John'};
            var record4 = {title: 'Henai', author:'Robert'};
            var records = [record1, record2, record3, record4 ];

            // Now apply template to produce desired formatted output
            records.each( function(conv) {
               alert( "Formatted Output : " + myTemplate.evaluate(conv) );
            });
         }
      </script>
   </head>

   <body>
      <p>Click the button to see the result.</p>
      <br />
      <br />
      <input type = "button" value = "Result" onclick = "showResult();"/>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

उत्पादन