पॉलिमर - त्वरित गाइड

Polymer.js Google द्वारा बनाई गई एक जावास्क्रिप्ट लाइब्रेरी है जो घटकों के साथ अनुप्रयोगों के निर्माण के लिए HTML तत्वों का पुन: उपयोग करने की अनुमति देता है।

पॉलिमर Google डेवलपर्स द्वारा विकसित एक ओपन-सोर्स जावास्क्रिप्ट लाइब्रेरी है और शुरू में 27 मई 2015 को जारी किया गया था। स्थिर रिलीज 1.7.0 है और यह 29 सितंबर, 2016 को जारी किया गया था।

Polymer.js का उपयोग क्यों करें?

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

  • यह Google द्वारा बनाया गया है जो वेब घटकों के साथ क्रॉस-ब्राउज़र संगत एप्लिकेशन प्रदान करता है।

  • यह एक तरफ़ा और दो तरफ़ा डेटा बाइंडिंग प्रदान करता है।

  • यह सरल घटकों से जटिल वेब अनुप्रयोगों तक परियोजनाओं के प्रबंधन के लिए पॉलिमर कमांड लाइन इंटरफ़ेस प्रदान करता है।

Polymer.js की विशेषताएं

  • यह एक जावास्क्रिप्ट पुस्तकालय है जो वेब मानकों एपीआई के शीर्ष पर बनाया गया है जो कस्टम HTML तत्वों के निर्माण की अनुमति देता है।

  • यह हमारे स्वयं के अनुकूलित और पुन: प्रयोज्य तत्वों को बनाने के लिए पॉलीफिल्स (वेब ​​घटक विनिर्देशों) प्रदान करता है।

  • यह वेब दस्तावेजों और वेब अनुप्रयोगों में पुन: प्रयोज्य विगेट्स के निर्माण के लिए वेब घटक मानकों का उपयोग करता है।

  • यह हाइब्रिड मोबाइल एप्लिकेशन के विकास के लिए Google सामग्री डिज़ाइन का उपयोग करता है।

  • यह पूरे नेटवर्क में कस्टम तत्वों को वितरित करता है और उपयोगकर्ता HTML आयात की मदद से इन तत्वों का उपयोग कर सकते हैं।

आपके सिस्टम में पॉलिमर को कॉन्फ़िगर करना आसान है। पॉलिमर को स्थापित करने के दो तरीके निम्नलिखित हैं।

  • पॉलिमर CLI (कमांड लाइन इंटरफ़ेस)
  • बोवर

पॉलिमर सीएलआई का उपयोग करके पॉलिमर स्थापित करना

Step 1 - निम्नलिखित npm कमांड का उपयोग करके पॉलिमर स्थापित करें।

npm install -g polymer-cli@next

Step 2 - निम्नलिखित कमांड का उपयोग करके सफल इंस्टॉलेशन और संस्करण की जांच करें।

polymer --version

यदि यह सफलतापूर्वक स्थापित हो गया है, तो यह संस्करण को निम्नानुसार दिखाएगा -

Step 3 - अपनी पसंद के नाम के साथ एक निर्देशिका बनाएं और उस निर्देशिका पर स्विच करें।

mkdir polymer-js 
cd polymer-js

Step 4- अपने प्रोजेक्ट को इनिशियलाइज़ करने के लिए, अपने पॉलीमर- jsdirectory में निम्न कमांड चलाएँ ।

polymer init

उपरोक्त कमांड को निष्पादित करने के बाद, यह कुछ इस तरह दिखाएगा -

C:\polymer-js>polymer init 
? Which starter template would you like to use? 
   1) polymer-1-element - A simple Polymer 1.0 element template 
   2) polymer-2-element - A simple Polymer 2.0 element template 
   3) polymer-1-application - A simple Polymer 1.0 application template 
   4) polymer-2-application - A simple Polymer 2.0 application 
   5) polymer-1-starter-kit - A Polymer 1.x starter application template, with 
      navigation and "PRPL pattern" loading 
   6) polymer-2-starter-kit - A Polymer 2.x starter application template, with 
      navigation and "PRPL pattern" loading 
   7) shop - The "Shop" Progressive Web App demo
   Answer: 4

Step 5 - ऊपर दिए गए विकल्पों में से पॉलिमर -2 एप्लिकेशन का चयन करें।

अब, निम्न कमांड का उपयोग करके अपनी परियोजना शुरू करें।

polymer serve

पॉलीमर का उपयोग कर बोवर का उपयोग करना

Step 1 - बोवर विधि का उपयोग करके खरोंच से शुरू करने के लिए, निम्न कमांड का उपयोग करके बोवर को स्थापित करें।

npm install -g bower

Step 2 - निम्न आदेश का उपयोग करके पॉलिमर स्थापित करें।

npm install -g polymer-cli@next

Step 3 - निम्न आदेश का उपयोग करके पॉलिमर के सफल स्थापना और संस्करण की जांच करें।

polymer --version

यदि यह सफलतापूर्वक स्थापित हो गया है, तो यह संस्करण को निम्नानुसार दिखाएगा -

0.18.0-pre.13.

Step 4 - बोवर से नवीनतम पॉलिमर 2.0 आरसी रिलीज़ स्थापित करने के लिए, निम्न कमांड का उपयोग करें।

bower install Polymer/polymer#^2.0.0-rc.3

Step 5 - एक बनाएँ index.html फ़ाइल और <head> टैग में निम्न कोड जोड़ें।

<script src = "/bower_components/webcomponentsjs/webcomponentsloader.js"></script> 
// it loads the polyfills 

<link rel = "import" href = "/bower_components/polymer/polymer.html"> 
// it import Polymer

Step 6 - निम्नलिखित कमांड का उपयोग करके अपनी परियोजना शुरू करें।

polymer serve

तैनाती के लिए भवन

परिनियोजन के लिए अपनी परियोजना बनाने के लिए, polymer build कमांड एक आसान तरीका है, जो कमांड लाइन के झंडे के आधार पर आपके कोड को छोटा, संक्षिप्त या बंडल करेगा।

एक सार्वभौमिक बिल्ड बनाने के लिए जो सभी ब्राउज़रों पर काम करता है, निम्नलिखित कमांड का उपयोग करें।

polymer build --js-compile

उपरोक्त कमांड प्रोजेक्ट का निर्माण / डिफ़ॉल्ट बनाने के लिए करेगा और आप निम्न कमांड का उपयोग करके इस निर्देशिका को शुरू कर सकते हैं।

polymer serve build/default

पॉलिमर 2.0 ईएस 6 और एचटीएमएल कस्टम तत्वों का उपयोग करता है। सर्वोत्तम अभ्यास के लिए, ES6 को पूर्ण ES6 समर्थन वाले ब्राउज़र में उपयोग करना हमेशा अच्छा होता है और ES5 को पुराने ब्राउज़रों के लिए संकलित करें जो ES6 का समर्थन नहीं करते हैं। निम्न तालिका आपके प्रोजेक्ट के लिए सबसे अच्छी रणनीति दिखाती है।

रणनीति क्रॉस-ब्राउज़र समर्थन के लिए सबसे आसान डब्ल्यूसी v1 प्रदर्शन के लिए सबसे इष्टतम
सर्वर कोई भी सर्वर काम करता है, जिसमें स्थैतिक भी शामिल हैं विभेदित सेवारत आवश्यक
तैनात कोड ES5 ट्रांसपोंड किया गया ES6
पॉलीफ़िल लोडर webcomponents-es5-loader.js webcomponents-loader.js

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

अनु क्रमांक। प्रकार और विवरण
1 एप्लिकेशन तत्व

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

2 लौह तत्व

एप्लिकेशन बनाने के लिए ये मूल बिल्डिंग ब्लॉक हैं।

3 कागज तत्व

पेपर तत्व Google के भौतिक डिज़ाइन दिशानिर्देशों को लागू करने के लिए डिज़ाइन किए गए UI घटकों का एक सेट हैं।

4 Google वेब घटक

Google वेब घटक Google API और सेवाओं के लिए वेब घटकों का भंडार है।

5 सोने के तत्व

ई-कॉमर्स-विशिष्ट उपयोग मामलों के लिए सोने के तत्वों का निर्माण किया जाता है।

6 नीयन तत्व

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

7 प्लैटिनम तत्व

प्लैटिनम तत्व आपके वेब पेज को एक सच्चे वेबऐप में बदलने के लिए सुविधाएँ प्रदान करते हैं।

8 अणु तत्व

अणु तत्व एक एप्लिकेशन को आसानी से विकसित करने में मदद करता है और इसका उपयोग प्लगइन्स के एक समूह को पॉलिमर एप्लिकेशन से जोड़ने के लिए किया जाता है।

पॉलिमर एक रूपरेखा है जो मानक HTML तत्वों का उपयोग करके कस्टम तत्वों को बनाने की अनुमति देता है। कस्टम वेब तत्व निम्नलिखित सुविधाएँ प्रदान करते हैं -

  • यह सहयोगी वर्ग के साथ कस्टम तत्व नाम प्रदान करता है।

  • जब आप कस्टम तत्व उदाहरण की स्थिति बदलते हैं, तो यह जीवनचक्र कॉलबैक का अनुरोध करेगा।

  • यदि आप एक उदाहरण पर विशेषताओं को बदलते हैं, तो कॉलबैक का अनुरोध किया जाएगा।

आप ईएस 6 वर्ग का उपयोग करके कस्टम तत्व को परिभाषित कर सकते हैं और क्लास को कस्टम तत्व के साथ जोड़ा जा सकता है जैसा कि निम्नलिखित कोड में दिखाया गया है।

//ElementDemo class is extending the HTMLElement 
class ElementDemo extends HTMLElement { 
   // code here
};

//link the new class with an element name
window.customElements.define('element-demo', ElementDemo);

कस्टम तत्व को नीचे दिखाए गए अनुसार एक मानक तत्व के रूप में इस्तेमाल किया जा सकता है -

<element-demo></element-demo>

Note - कस्टम एलिमेंट नाम को लोअर केस लेटर से शुरू होना चाहिए और नामों के बीच डैश होना चाहिए।

कस्टम तत्व जीवनचक्र

कस्टम तत्व जीवनचक्र कस्टम तत्व प्रतिक्रियाओं का एक सेट प्रदान करता है जो तत्व जीवनचक्र में परिवर्तन के लिए जिम्मेदार होते हैं और निम्न तालिका में परिभाषित किए जाते हैं।

अनु क्रमांक। प्रतिक्रियाओं और विवरण
1

constructor

जब आप कोई तत्व बनाते हैं या पहले से निर्मित तत्व को परिभाषित करते हैं, तो यह तत्व प्रतिक्रिया कहलाएगा।

2

connectedCallback

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

3

disconnectedCallback

जब आप किसी दस्तावेज़ से कोई तत्व निकालते हैं, तो यह तत्व प्रतिक्रिया कहलाएगी।

4

attributeChangedCallback

जब भी आप दस्तावेज़ से किसी तत्व को बदलते हैं, जोड़ते हैं, हटाते हैं या प्रतिस्थापित करते हैं, तो यह तत्व प्रतिक्रिया कहलाएगा।

तत्व उन्नयन

हम विनिर्देशन द्वारा उन्हें परिभाषित करने से पहले कस्टम तत्वों का उपयोग कर सकते हैं और किसी तत्व के किसी भी मौजूदा उदाहरण को उस तत्व में एक परिभाषा जोड़कर कस्टम वर्ग में अपग्रेड किया जाएगा।

कस्टम तत्व स्थिति में निम्न मान शामिल हैं -

  • uncustomized - मान्य कस्टम तत्व नाम या तो एक अंतर्निहित तत्व या एक अज्ञात तत्व है, जो एक कस्टम तत्व नहीं बन सकता है।

  • undefined - तत्व में एक मान्य कस्टम तत्व नाम हो सकता है, लेकिन इसे परिभाषित नहीं किया जा सकता है।

  • custom - तत्व में एक मान्य कस्टम तत्व नाम हो सकता है, जिसे परिभाषित और उन्नत किया जा सकता है।

  • failed - अमान्य वर्ग के विफल तत्व को अपग्रेड करने का प्रयास करना।

एक तत्व को परिभाषित करना

एक कस्टम तत्व को एक वर्ग बनाकर परिभाषित किया जा सकता है जो Polymer.Element का विस्तार करता है और यह customElements.define विधि में कक्षा उत्तीर्ण करता है। वर्ग में गेटर विधि होती है जो कस्टम तत्व का HTML टैग नाम लौटाती है। उदाहरण के लिए -

//ElementDemo class is extending the Polymer.Element 
class ElementDemo extends Polymer.Element {
   static get is() { return 'element-demo'; }
   static get properties() {
      . . .
      . . .
   }
   constructor(){
      super();
      . . .
      . . .
   }
   . . .
   . . .
}

//Associate the new class with an element name
window.customElements.define(ElementDemo.is, ElementDemo);

// create an instance with createElement
var el1 = document.createElement('element-demo');

आयात और एपीआई

पॉलिमर तत्वों को निम्नलिखित तीन HTML आयातों को निर्दिष्ट करके परिभाषित किया जा सकता है -

  • polymer-element.html - यह Polymer.Element बेस क्लास को निर्दिष्ट करता है।

  • legacy-element.html- यह Polymer.Element को Polymer.LegacyElement बेस क्लास का उपयोग करके बढ़ाता है और 1.x संगत विरासत एपीआई जोड़ता है। यह विरासत पॉलिमर () फैक्टरी विधि को परिभाषित करके संकर तत्व भी बनाता है।

  • polymer.html - इसमें हेल्पर तत्वों के साथ पॉलिमर बेस कक्षाएं शामिल हैं, जो 1.x पोलीमर.html में शामिल थे।

मुख्य HTML दस्तावेज़ में एक तत्व को परिभाषित करें

आप HTMLImports.whenReady () फ़ंक्शन का उपयोग करके मुख्य HTML दस्तावेज़ में एक तत्व को परिभाषित कर सकते हैं।

उदाहरण

निम्न उदाहरण दिखाता है कि मुख्य HTML दस्तावेज़ में किसी तत्व को कैसे परिभाषित किया जाए। एक index.html फ़ाइल बनाएँ और निम्न कोड जोड़ें।

<!doctype html>
<html lang = "en">
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "define-element.html">
   </head>
   
   <body>
      <define-element></define-element>
   </body>
</html>

अब define-element.html नामक एक कस्टम एलिमेंट बनाएं और इसमें निम्न कोड शामिल करें।

<dom-module id = "define-element">
   <template>
      <h2>Welcome to Tutorialspoint!!!</h2>
   </template>
   
   <script>
      HTMLImports.whenReady(function(){
         Polymer ({
            is: "define-element"
         })
      })  
   </script>
</dom-module>

उत्पादन

एप्लिकेशन को चलाने के लिए, बनाई गई प्रोजेक्ट डायरेक्टरी में नेविगेट करें और निम्न कमांड चलाएँ।

polymer serve

अब ब्राउज़र खोलें और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

एक लिगेसी तत्व को परिभाषित करें

पॉलिमर फ़ंक्शन का उपयोग करके एक तत्व को पंजीकृत करने के लिए विरासत तत्व का उपयोग किया जा सकता है, जो एक नए तत्व के लिए प्रोटोटाइप लेता है। प्रोटोटाइप में होना चाहिएis जो कस्टम तत्व के लिए HTML टैग नाम को परिभाषित करता है।

उदाहरण

//registering an element
ElementDemo = Polymer ({
   is: 'element-demo',
   
   //it is a legecy callback, called when the element has been created
   created: function() {
     this.textContent = 'Hello World!!!';
   }
});

//'createElement' is used to create an instance
var myelement1 = document.createElement('element-demo');

//use the constructor create an instance
var myelement2 = new ElementDemo();

जीवनचक्र कॉलबैक

जीवनचक्र कॉलबैक का उपयोग अंतर्निहित सुविधाओं के कार्यों को पूरा करने के लिए किया जाता है Polymer.Elementकक्षा। पॉलिमर तैयार कॉलबैक का उपयोग करता है, जिसे पॉलिमर डोम तत्वों को बनाने और शुरू करने के लिए पूरा करने पर लागू किया जाएगा।

Polymer.js में विरासत कॉलबैक की सूची निम्नलिखित है।

  • created - यह तब कहा जाता है जब आप संपत्ति मूल्यों को स्थापित करने और स्थानीय डोम को शुरू करने से पहले एक तत्व बनाते हैं।

  • ready - यह तब कहा जाता है जब आप संपत्ति मूल्यों को स्थापित करने और स्थानीय डोम को शुरू करने के बाद एक तत्व बनाते हैं।

  • attached - यह तत्व को दस्तावेज़ में संलग्न करने के बाद कहा जाता है और एक तत्व के जीवनकाल में एक से अधिक बार बुलाया जा सकता है।

  • detached - यह दस्तावेज़ से तत्व को अलग करने के बाद कहा जाता है और एक तत्व के पूरे जीवनकाल में एक से अधिक बार कहा जा सकता है।

  • attributeChanged - यह तब कहा जाता है जब किसी तत्व की विशेषताओं में परिवर्तन होते हैं और यह विशेषता परिवर्तनों को धारण करता है, जो घोषित गुणों के अनुरूप नहीं होते हैं।

घोषणा करने के गुण

गुणों को डेटा सिस्टम में डिफ़ॉल्ट मान और अन्य विशिष्ट सुविधाओं को जोड़ने के लिए एक तत्व पर घोषित किया जा सकता है और उन्हें निम्नलिखित विशेषताओं को निर्दिष्ट करने के लिए इस्तेमाल किया जा सकता है -

  • यह संपत्ति प्रकार और डिफ़ॉल्ट मान निर्दिष्ट करता है।

  • संपत्ति के मूल्य में परिवर्तन होने पर यह पर्यवेक्षक विधि कहलाता है।

  • यह संपत्ति के मूल्य में अप्रत्याशित परिवर्तनों को रोकने के लिए केवल-पढ़ने की स्थिति को निर्दिष्ट करता है।

  • यह दो-तरफ़ा डेटा बाइंडिंग के लिए समर्थन प्रदान करता है, जो संपत्ति के मूल्यों को बदलने पर एक घटना को ट्रिगर करता है।

  • यह एक गणना की गई संपत्ति है, जो अन्य गुणों के आधार पर गतिशील रूप से एक मूल्य की गणना करता है।

  • जब आप गुण मान बदलते हैं, तो यह संबंधित विशेषता मान को अपडेट और प्रतिबिंबित करता है।

निम्न तालिका प्रत्येक गुण के लिए कुंजियाँ दिखाती है, जो गुण ऑब्जेक्ट द्वारा समर्थित हैं।

अनु क्रमांक। कुंजी और विवरण प्रकार
1

type

यह एक विशेषता से भिन्न होता है जिसका गुण प्रकार प्रकार के निर्माता का उपयोग करके निर्धारित किया जाता है।

कंस्ट्रक्टर (बुलियन, दिनांक, संख्या, स्ट्रिंग, सरणी या ऑब्जेक्ट)
2

value

यह संपत्ति के लिए डिफ़ॉल्ट मान को निर्दिष्ट करता है और यदि यह एक फ़ंक्शन है, तो यह संपत्ति के डिफ़ॉल्ट मूल्य के रूप में वापसी मूल्य का उपयोग करता है।

बूलियन, संख्या, स्ट्रिंग या फ़ंक्शन।
3

reflectToAttribute

यदि यह कुंजी सही है, तो यह होस्ट नोड पर संबंधित विशेषता सेट करता है। यदि आप बूलियन के रूप में गुण मान सेट करते हैं, तो विशेषता को मानक HTML बूलियन विशेषता के रूप में बनाया जा सकता है।

बूलियन
4

readOnly

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

बूलियन
5

notify

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

बूलियन
6

computed

जब भी आप परिवर्तन करते हैं, तो आप एक तर्क के मूल्य की गणना कर सकते हैं, विधि को लागू करके और मूल्य को विधि के नाम और तर्क सूची के रूप में सरल किया जाएगा।

तार
7

observer

विधि नाम को लागू करें, जो एक मूल्य द्वारा सरलीकृत किया जाता है, जब संपत्ति मूल्य बदल जाता है।

तार

देशभक्ति का गुणगान करें

यदि गुण ऑब्जेक्ट में गुण को कॉन्फ़िगर किया गया है, तो निर्दिष्ट गुण के प्रकार और गुण उदाहरण पर उसी गुण नाम के अनुसार गुण का मिलान करने वाले गुण नाम का वर्णन करें।

आप निर्दिष्ट प्रकार को सीधे संपत्ति के मूल्य के रूप में सेट कर सकते हैं, यदि गुण ऑब्जेक्ट में परिभाषित कोई अन्य गुण विकल्प नहीं हैं; अन्यथा, यह गुण कॉन्फ़िगरेशन ऑब्जेक्ट में टाइप कुंजी के लिए मूल्य प्रदान करेगा।

बूलियन गुण कॉन्फ़िगर करना

बूलियन प्रॉपर्टी को मार्कअप से कॉन्फ़िगर किया जा सकता है, इसे गलत पर सेट किया जा सकता है और यदि यह सही पर सेट है, तो आप मार्कअप से कॉन्फ़िगर नहीं कर सकते क्योंकि मूल्य के साथ या उसके बिना विशेषता समान है। इसलिए, इसे वेब प्लेटफॉर्म में विशेषताओं के लिए एक मानक व्यवहार के रूप में जाना जाता है।

ऑब्जेक्ट और एरे प्रॉपर्टीज को JSON फॉर्मेट में पास करके कॉन्फ़िगर किया जा सकता है -

<element-demo player = '{ "name": "Sachin", "country": "India" }'></element-demo>

डिफ़ॉल्ट संपत्ति मान कॉन्फ़िगर करना

डिफ़ॉल्ट ऑब्जेक्ट को गुण ऑब्जेक्ट में मान फ़ील्ड का उपयोग करके कॉन्फ़िगर किया जा सकता है और यह या तो आदिम मान हो सकता है, या एक फ़ंक्शन जो मान लौटाता है।

उदाहरण

निम्न उदाहरण में दर्शाया गया है कि गुण ऑब्जेक्ट में डिफ़ॉल्ट गुण मान को कॉन्फ़िगर कैसे करें।

<link rel = "import" href = "../../bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id="polymer-app">
   <template>
      <style>
         :host {
            color:#33ACC9;
         }
      </style>
      <h2>Hello...[[myval]]!</h2>	
   </template>

   <script>
      //cusom element extending the Polymer.Element class
      class PolymerApp extends Polymer.Element {
         static get is() { return 'polymer-app'; }
         static get properties() {
            return {
               myval: {
                  type: String,
                  //displaying this value on screen
                  value: 'Welcome to Tutorialspoint;!!!'
               },
               data: {
                  type: Object,
                  notify: true,
                  value: function() { return {}; }
               }
            }
         }
      }
      window.customElements.define(PolymerApp.is, PolymerApp);
   </script>
</dom-module>

उत्पादन

पिछले उदाहरण में दिखाए अनुसार एप्लिकेशन को चलाएं, और नेविगेट करें http://127.0.0.1:8000/। निम्नलिखित उत्पादन होगा।

पढ़ें- केवल गुण

प्रॉपर्टी ऑब्जेक्ट में रीडऑनली फ्लैग को सही पर सेट करके आप उत्पादित डेटा पर अप्रत्याशित बदलाव से बच सकते हैं। तत्व संपत्ति के मूल्य को बदलने के लिए, कन्वेंशन _setProperty (मूल्य) के सेटर का उपयोग करता है।

उदाहरण

निम्नलिखित उदाहरण में गुण ऑब्जेक्ट में केवल-पढ़ने के गुणों का उपयोग दर्शाया गया है। एक index.html फ़ाइल बनाएँ और उसमें निम्न कोड जोड़ें

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
    
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "my-element.html">
   </head>
   
   <body>
      <my-element></my-element>
   </body>
</html>

अब, my-element.html नामक एक अन्य फ़ाइल बनाएँ और निम्नलिखित कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">
<link rel = "import" href = "prop-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "my-element">
   <template>
      <prop-element my-prop = "{{demoProp}}"></prop-element>
      <p>Present value: <span>{{demoProp}}</span></p>
   </template>

   <script>
      Polymer ({
         is: "my-element", properties: {
            demoProp: String
         }
      });
   </script>
</dom-module>

इसके बाद, Prop-element.html नामक एक और फ़ाइल बनाएँ और निम्नलिखित कोड जोड़ें।

//it specifies the start of an element's local DOM
<dom-module id="prop-element">
   <template>
      <button on-click="onClickFunc">Change value</button>
   </template>
   
   <script>
      Polymer ({
         is: "prop-element", properties: {
            myProp: {
               type: String,
               notify: true,
               readOnly: true,
               value: 'This is initial value...'
            }
         },
         onClickFunc: function(){
            this._setMyProp('This is new value after clicking the button...');
         }
      });
   </script>
</dom-module>

उत्पादन

पिछले उदाहरण में दिखाए अनुसार एप्लिकेशन को चलाएं, और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

बटन पर क्लिक करने के बाद, यह निम्न स्क्रीनशॉट में दिखाए गए मान को बदल देगा।

गुणों को दर्शाते हुए गुण

HTML विशेषता को गुण मान के साथ सिंक्रनाइज़ किया जा सकता है reflectToAttribute गुण कॉन्फ़िगरेशन ऑब्जेक्ट में किसी गुण पर सत्य के लिए।

विशेषता का सत्यापन करें

किसी गुण को गुण को दर्शाते या बांधते समय गुण मान को विशेषता पर क्रमबद्ध किया जा सकता है, और डिफ़ॉल्ट रूप से मूल्य के वर्तमान प्रकार के आधार पर क्रमबद्ध किया जा सकता है।

  • String - सीरियल की कोई जरूरत नहीं है।

  • Date or Number - मानों को क्रमांकित करने के लिए स्ट्रैस्ट्रिंग का उपयोग करें।

  • Boolean - प्रदर्शित गैर-मूल्यवान विशेषता को सही या गलत के रूप में सेट करें।

  • Array or Object - मान को क्रमबद्ध करने के लिए JSON.stringify का उपयोग करें।

शैडो डोम, भवन घटकों के लिए उपयोग किए जाने वाले DOM का एक नया गुण है।

Example

निम्नलिखित कोड में, हेडर घटक में पृष्ठ शीर्षक और मेनू बटन शामिल है।

<header-demo>
   <header>
      <h1>
         <button>

शैडो डोम बच्चों को स्कॉप्ड सबट्री में पता लगाने की अनुमति देता है, जिसे के रूप में जाना जाता है shadow tree

<header-demo>
   #shadow-root
   <header>
      <h1>
      <button>

शैडो-रूट रूट को शैडो ट्री के शीर्ष के रूप में कहा जाता है और जो तत्व ट्री से जुड़ा होता है उसे शैडो होस्ट (हेडर-डेमो) कहा जाता है। इस छाया होस्ट में शैडोराट नामक गुण शामिल है, जो छाया रूट को निर्दिष्ट करता है। छाया रूट होस्ट गुण का उपयोग करके होस्ट तत्व की पहचान करता है।

शैडो डोम और रचना

तत्व डोम के बच्चों के बजाय छाया वृक्ष का प्रतिपादन किया जा सकता है, यदि छाया डोम में कोई तत्व है। तत्व के बच्चों को छाया पेड़ में <स्लॉट> तत्व जोड़कर प्रदान किया जा सकता है।

उदाहरण के लिए, <हेडर-डेमो> के लिए निम्नलिखित शैडो ट्री का उपयोग करें।

<header>
   <h1><slot></slot></h1>
   &ltbutton>Menu</button>
</header>

बच्चों को <my-header> तत्व के रूप में जोड़ें -

<header-demo>Shadow DOM</header-demo>

हेडर ऊपर निर्दिष्ट बच्चों के साथ </ स्लॉट> तत्व की जगह लेता है -

<header-demo>
   <header>
      <h1>Shadow DOM</h1>
      <button>Menu</button>
   </header>
</header-demo>

फ़ॉलबैक सामग्री

फ़ॉलबैक सामग्री तब प्रदर्शित की जा सकती है जब स्लॉट में कोई नोड आवंटित नहीं होता है। उदाहरण के लिए -

<my-element>
   #shadow-root
   <slot id = "myimgicon">
      <img src = "img-demo.png">
   </slot>
   <slot></slot>
<my-element>

आप एक तत्व के लिए अपना खुद का आइकन प्रदान कर सकते हैं -

<my-element>
   <img slot = "myimgicon" src = "warning.png">
<my-element>

बहु-स्तरीय वितरण

आप स्लॉट तत्व को एक स्लॉट में आवंटित कर सकते हैं, जिसे बहु-स्तरीय वितरण के रूप में जाना जाता है।

उदाहरण के लिए, छाया के पेड़ के दो स्तरों को नीचे दिखाए अनुसार लें -

<parent-element>
   #shadow-root
      <child-element>
      <!-- display the light DOM children of parent-element inside child-element -->
      <slot id = "parent-slot">
	  
   <child-element>
      #shadow-root
         <div>
            <!-- Render the light DOM children inside div by using child-element -->
            <slot id = "child-slot">

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

<parent-element>
   <p>This is light DOM</p>
<parent-element>

एक चपटे पेड़ की संरचना निम्नलिखित की तरह दिखती है।

<parent-element>
   <child-element>
      <div>
         <slot id = "child-slot">
            <slot id = "parent-slot">
               <p>This is light DOM</p>

वितरण की जाँच के लिए शैडो डोम निम्नलिखित स्लॉट एपीआई का उपयोग करता है -

  • HTMLElement.assignedSlot - यह एक तत्व के लिए स्लॉट आवंटित करता है और शून्य देता है, अगर किसी स्लॉट में किसी तत्व का आवंटन नहीं होता है।

  • HTMLSlotElement.assignedNodes - यह स्लॉट के साथ नोड्स की सूची प्रदान करता है और वितरित नोड्स को वापस करता है, जब आप समतल विकल्प को सही पर सेट करते हैं।

  • HTMLSlotElement.slotchange - यह घटना तब ट्रिगर होती है जब स्लॉट के वितरित नोड्स में परिवर्तन होते हैं।

इवेंट रिटारगेटिंग

यह घटना के लक्ष्य को निर्दिष्ट करता है जिसमें तत्व को सुनने वाले तत्व के समान दायरे में दर्शाया जा सकता है। यह एक कस्टम तत्व से एक घटना प्रदान करता है, जो दिखता है कि यह कस्टम तत्व टैग से आ रहा है, जैसा कि एक तत्व के विपरीत है।

Example

निम्न उदाहरण पॉलिमर.जैस में इवेंट रिटारगेटिंग के उपयोग को दर्शाता है। Index.html नामक एक फाइल बनाएं और उसमें निम्न कोड डालें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "retarget-event.html">
   </head>
   
   <body>
      <template id = "myapp" is = "dom-bind">
         <retarget-event on-tap = "clicky"></retarget-event>
      </template>
      
      <script>
         var myval = document.querySelector('#myapp');
         myval.clicky = function(e) {
            console.log("The retargeted result:", Polymer.dom(myval));
            console.log("Normal result:", e);
         };
      </script>
   </body>
</html>

अब, retarget-event.html नामक एक अन्य फ़ाइल बनाएं और निम्न कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "retarget-event">

   <template>
      <span>Click on this text to see result in console...</span>
   </template>

   <script>
      Polymer ({
         is: 'retarget-event',
      });
   </script>
</dom-module>

Output

एप्लिकेशन को चलाने के लिए, बनाई गई प्रोजेक्ट डायरेक्टरी में नेविगेट करें और निम्न कमांड चलाएँ।

polymer serve

अब ब्राउज़र खोलें और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

उपरोक्त पाठ पर क्लिक करें और फिर से स्क्रीनशॉट को दिखाने के लिए कंसोल को खोलें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

छाया डोम स्टाइलिंग

आप शैली गुणों का उपयोग करके शैडो डोम को स्टाइल कर सकते हैं, जो होस्ट से छाया ट्री में विरासत में मिला है।

Example

<style>
   .mydemo { background-color: grey; }
</style>

<my-element>
#shadow-root
   <style>
      //this div will have blue background color
      div { background-color: orange; }
   </style>
   <div class = "mydemo">Demo</div>

DOM टेंपलेटिंग

DOM उपचारात्मक का उपयोग कर एक तत्व के लिए DOM सबट्री बनाई जा सकती है। आप तत्व के लिए छाया रूट बना सकते हैं और एक तत्व में DOM टेम्पलेट जोड़कर टेम्पलेट को छाया पेड़ में कॉपी कर सकते हैं।

DOM टेम्पलेट को दो तरीकों से निर्दिष्ट किया जा सकता है -

  • एक <डोम-मॉड्यूल> तत्व बनाएं, जो एक आईडी विशेषता के साथ एक तत्व के नाम से मेल खाना चाहिए।

  • एक <टेम्पलेट> तत्व को <डोम-मॉड्यूल> के अंदर परिभाषित करें।

Example

<dom-module id = "my-template">
   <template>I am in my template!!!</template>

   <script>
      class MyTemplate extends Polymer.Element {
         static get is() { return  'my-template' }
      }
      customElements.define(MyTemplate.is, MyTemplate);
   </script>
</dom-module>

स्टाइल ए एलिमेंट का शैडो डोम

शैडो डोम अपने तत्व के दायरे के बाहर इसे लागू किए बिना स्टाइल गुणों जैसे फोंट, पाठ रंग और कक्षाओं का उपयोग करके कस्टम तत्वों को स्टाइल करने की अनुमति देता है।

का उपयोग करते हुए मेजबान तत्व को स्टाइल करते हैं :hostचयनकर्ता (छाया डोम से जुड़ा एक तत्व मेजबान के रूप में कहा जाता है)। बहुलक- app.html नामक एक फ़ाइल बनाएँ और इसमें निम्न कोड जोड़ें।

<link rel = "import" href = "../../bower_components/polymer/polymer-element.html">

<dom-module id = "polymer-app">
   <template>
      <style>
         :host {
            color:#33ACC9;
         }
      </style>
      <h2>Hello...[[myval]]!</h2>	
  </template>

  <script>
      class PolymerApp extends Polymer.Element {
         static get is() { return 'polymer-app'; }
         static get properties() {
            return {
               myval: {
                  type: String, value: 'Welcome to Tutorialspoint!!!'
               }
            };
         }
      }

      window.customElements.define(PolymerApp.is, PolymerApp);
   </script>
</dom-module>

एप्लिकेशन को पिछले अध्याय में दिखाए अनुसार चलाएं और नेविगेट करेंhttp://127.0.0.1:8000/। निम्नलिखित उत्पादन होगा।

शैली Slotted सामग्री

इसे बनाना संभव है slots एक तत्व के टेम्पलेट में, जो रन टाइम पर कब्जा कर लिया जाता है।

Example

निम्न उदाहरण में तत्व के टेम्पलेट में स्लॉटेड सामग्री के उपयोग को दर्शाया गया है। एक index.html फ़ाइल बनाएँ और उसमें निम्न कोड जोड़ें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "slotted-content.html">
   </head>
   
   <body>
      <slotted-content>
         <div slot = "text">This is Polymer.JS Slotted Content Example</div>
      </slotted-content> 
   </body>
</html>

अब slotted-content.html नामक एक और फ़ाइल बनाएँ और निम्नलिखित कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

<dom-module id = "slotted-content">
   <template>
      <style>
         ::slotted(*) {
            font-family: sans-serif;
            color:#E94A9D;
         }
      </style>
      
      <h2>Hello...[[prop1]]</h2>
      <h3>
         <div><slot name='text'></slot></div>
      </h3>
   </template>
   
   <script>
      Polymer ({
         is: 'slotted-content', properties: {
            prop1: {
               type: String,
               value: 'Welcome to Tutorialspoint!!',
            },
         },
      });
   </script>
</dom-module>

पिछले उदाहरण में दिखाए अनुसार एप्लिकेशन को चलाएं, और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

स्टाइल मॉड्यूल का उपयोग करना

आप शैली मॉड्यूल के साथ तत्वों के बीच शैलियों को साझा कर सकते हैं। शैली मॉड्यूल में शैलियों को निर्दिष्ट करें, और उन्हें तत्वों के बीच साझा करें।

Example

निम्न उदाहरण दिखाता है कि तत्वों के बीच शैली मॉड्यूल का उपयोग कैसे करें। एक index.html फ़ाइल बनाएँ और उसमें निम्न कोड जोड़ें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "style-module.html">
   </head>
   
   <body>
      <style-module></style-module> 
   </body>
</html>

निम्नलिखित कोड के साथ स्टाइल-मॉड्यूल.html नामक एक अन्य फ़ाइल बनाएं।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

<dom-module id = "style-module">
   <template>
      <!-- here, including the imported styles from colors-module page -->
      <style include="colors-module"></style>
      <style>
         :host {
            font-family: sans-serif;
            color: green;    
         }
      </style>
      
      <h2>Hello...[[prop1]]</h2>
      <p class = "color1">Sharing styles with style modules 1...</p>
      <p class = "color2">Sharing styles with style modules 2...</p>
      <p class = "color3">Sharing styles with style modules 3...</p>
   </template>
   
   <script>
      Polymer ({
         is: 'style-module', properties: {
            prop1: {
               type: String, value: 'Welcome to Tutorialspoint!!',
            },
         },
      });
   </script>
</dom-module>

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

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

<dom-module id = 'colors-module'>
   <template>
      <style>
         p.color1 {
            color: #EA5AA5;
         }
         p.color2 {
            color: #4B61EA;
         }
         p.color3 {
            color: #D3AA0A;
         }
      </style>
   </template>
</dom-module>

एप्लिकेशन चलाएं और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

कस्टम गुण का उपयोग करें

कस्टम सीएसएस गुण पॉलिमर तत्व का उपयोग करके आपके आवेदन में तत्व की उपस्थिति को स्टाइल करने के लिए उपयोग किया जा सकता है। कस्टम गुण CSS वैरिएबल को कैस्केडिंग प्रदान करते हैं, जिसका उपयोग कस्टम तत्वों के वातावरण के बाहर किया जा सकता है जो स्टाइल डेटा के माध्यम से स्टाइल डेटा को बिखरने से दूर रखते हैं।

कस्टम गुणों को मानक CSS गुणों के समान परिभाषित किया जा सकता है, जो रचित DOM ट्री से विरासत में मिला है। पिछले उदाहरण में, आप तत्वों के लिए परिभाषित कस्टम सीएसएस गुण देख सकते हैं।

सीएसएस वंशानुक्रम के तहत, यदि किसी तत्व के लिए कोई शैली परिभाषित नहीं है, तो यह अपने माता-पिता से शैली का वारिस करेगा जैसा कि निम्नलिखित कोड में दिखाया गया है।

<link rel = "import" href = "components/polymer/myelement-style.html">
<myelement-style>
   <style is = "myelement-style">
      p {
         color: var(--paper-red-900);
      }
      paper-checkbox {
         --paper-checkbox-checked-color: var(--paper-red-900);
      }
   </style>
</myelement-style>

<body>
   <p><paper-checkbox>Check Here</paper-checkbox></p>
</body>

घटनाओं का उपयोग उन तत्वों द्वारा किया जाता है जो मूल वृक्ष के राज्य परिवर्तनों को मूल तत्वों के साथ संचार कर सकते हैं और घटनाओं को बनाने, भेजने और सुनने के लिए मानक DOM APIs का उपयोग करते हैं। annotated event listeners पॉलिमर द्वारा उपयोग किया जाता है, जो ईवेंट श्रोताओं को DOM टेम्पलेट के छोटे विखंडू के रूप में परिभाषित करता है और टेम्पलेट में वनवेंट एनोटेशन का उपयोग करके DOM बच्चों में जोड़ा जा सकता है।

उदाहरण

निम्न उदाहरण टेम्पलेट में एनोटेट इवेंट श्रोताओं को जोड़ता है। Index.html नामक एक फाइल बनाएं और उसमें निम्न कोड डालें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href="bower_components/polymer/polymer.html">
      <link rel = "import" href = "annotated-eventlistners.html">
   </head>
   
   <body>
      <template id = "myapp" is = "dom-bind">
         //tap event is part of gesture events that fires consistently across both mobile
         //and desktop devices
         <annotated-eventlistners on-tap = "myClick"></annotated-eventlistners>
      </template>
      
      <script>
         var myval = document.querySelector('#myapp');
         myval.myClick =  function(e) {
            console.log('Hello World!!!');
         };
      </script>
   </body>
</html>

उत्पादन

एप्लिकेशन को चलाने के लिए, बनाई गई प्रोजेक्ट डायरेक्टरी में नेविगेट करें और निम्न कमांड चलाएँ।

polymer serve

अब ब्राउज़र खोलें और नेविगेट करें http://127.0.0.1:8000/। निम्नलिखित उत्पादन होगा।

निम्न स्क्रीनशॉट में दिखाए अनुसार कंसोल में परिणाम देखने के लिए पाठ पर क्लिक करें।

कस्टम ईवेंट

कस्टम ईवेंट को मानक CustomEvent कंस्ट्रक्टर और होस्ट तत्व से प्रेषण विधि का उपयोग करके ट्रिगर किया जा सकता है।

निम्नलिखित उदाहरण पर विचार करें जो मेजबान तत्व से कस्टम इवेंट को ट्रिगर करता है। Index.html फ़ाइल खोलें और उसमें निम्न कोड जोड़ें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "custom-event.html">
   </head>
   
   <body>
      <custom-event></custom-event>
      <script>
         document.querySelector('custom-event').addEventListener('customValue', function (e) {
            console.log(e.detail.customval); // true
         })
      </script>
   </body>
</html>

अब, custom-event.html नामक एक और फ़ाइल बनाएँ और निम्नलिखित कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "custom-event">
   <template>
      <h2>Custom Event Example</h2>
      <button on-click = "myClick">Click Here</button>
   </template>
   
   <script>
      Polymer ({
         is: "custom-event", myClick(e) {
            this.dispatchEvent(new CustomEvent('customValue', {detail: {customval: true}}));
         }
      });
   </script>
</dom-module>

उत्पादन

पिछले उदाहरण में दिखाए गए अनुसार एप्लिकेशन चलाएं और नेविगेट करें http://127.0.0.1:8000/। निम्नलिखित उत्पादन होगा।

अब बटन पर क्लिक करें, कंसोल खोलें, और निम्न स्क्रीनशॉट में दिखाए गए अनुसार कस्टम ईवेंट के लिए सही मान देखें।

अब "इवेंट रिटारगेटिंग" के साथ आगे बढ़ रहा है, जो ईवेंट के लक्ष्य को निर्दिष्ट करता है जहां तत्व को सुनने वाले तत्व के समान दायरे में दर्शाया जा सकता है। उदाहरण के लिए, लक्ष्य को मुख्य दस्तावेज़ में एक तत्व के रूप में माना जा सकता है, जबकि मुख्य दस्तावेज़ में एक श्रोता का उपयोग करते हुए, छाया वृक्ष में नहीं। आप अधिक स्पष्टीकरण और उदाहरण के लिए पॉलिमर छाया डोम स्टाइलिंग अध्याय का उल्लेख कर सकते हैं ।

इशारे की घटनाएँ

जेस्चर घटनाओं का उपयोग उपयोगकर्ता इंटरैक्शन के लिए किया जा सकता है, जो स्पर्श और मोबाइल डिवाइस दोनों पर बेहतर इंटरैक्शन को परिभाषित करते हैं। उदाहरण के लिए, टैप इवेंट जेस्चर इवेंट्स का एक हिस्सा है जो मोबाइल और डेस्कटॉप दोनों डिवाइसों पर लगातार फायर करता है।

आप इस अध्याय की शुरुआत में बताए गए इशारे की घटना के लिए उदाहरण का उल्लेख कर सकते हैं, जो उपयोग करता है on-tap टेम्पलेट में एनोटेट इवेंट श्रोताओं को जोड़ने वाली घटना।

निम्न तालिका विभिन्न प्रकार के हावभाव ईवेंट प्रकारों को सूचीबद्ध करती है।

अनु क्रमांक। ईवेंट प्रकार और विवरण गुण
1

down

यह निर्दिष्ट करता है कि उंगली / बटन नीचे चला गया है।

  • x - यह क्लाइंटएक्स को किसी घटना के लिए समन्वय प्रदान करता है।

  • y - यह एक घटना के लिए ग्राहक समन्वय प्रदान करता है।

  • sourceEvent - यह DOM इवेंट के कारण डाउन एक्शन को निर्दिष्ट करता है।

2

up

यह निर्दिष्ट करता है कि उंगली / बटन ऊपर चला गया है।

  • x - यह क्लाइंटएक्स को किसी घटना के लिए समन्वय प्रदान करता है।

  • y - यह एक घटना के लिए ग्राहक समन्वय प्रदान करता है।

  • sourceEvent - यह DOM ईवेंट के कारण हुई अप क्रिया को निर्दिष्ट करता है।

3

tap

यह ऊपर और नीचे की क्रियाओं की घटना को निर्दिष्ट करता है।

  • x - यह क्लाइंटएक्स को किसी घटना के लिए समन्वय प्रदान करता है।

  • y - यह एक घटना के लिए ग्राहक समन्वय प्रदान करता है।

  • sourceEvent - यह DOM इवेंट के कारण होने वाले टैप एक्शन को निर्दिष्ट करता है।

4

track

यह ऊपर और नीचे की क्रियाओं की घटना को निर्दिष्ट करता है।

  • x - यह क्लाइंटएक्स को किसी घटना के लिए समन्वय प्रदान करता है।

  • y - यह एक घटना के लिए ग्राहक समन्वय प्रदान करता है।

  • state - यह एक प्रकार का स्ट्रिंग है जो ट्रैकिंग स्थिति को निर्दिष्ट करता है।

  • dx - यह क्षैतिज रूप से पिक्सेल में परिवर्तन करता है, जब आप पहली घटना को ट्रैक करते हैं।

  • dy - जब आप पहली ईवेंट को ट्रैक करते हैं, तो यह पिक्सेल में बदलाव करता है।

  • ddx - यह क्षैतिज रूप से पिक्सेल में परिवर्तन करता है, जब आप अंतिम ईवेंट को ट्रैक करते हैं।

  • ddy - जब आप अंतिम ईवेंट को ट्रैक करते हैं तो यह लंबवत रूप से पिक्सेल में बदलाव करता है।

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

उदाहरण

निम्न उदाहरण टेम्पलेट में इशारे के घटना प्रकारों के उपयोग को निर्दिष्ट करता है। Index.html नामक एक फाइल बनाएं और उसमें निम्न कोड रखें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "gesture-event.html">
   </head>
   
   <body>
      <gesture-event></gesture-event>
   </body>
</html>

अब, जेस्चर-ईवेंट.html नामक एक अन्य फ़ाइल बनाएं और निम्नलिखित कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "gesture-event">
   <template>
      <style>
         #box {
            width: 200px;
            height: 200px;
            background: #D7D0B7;
         }
      </style>
      
      <h2>Gesture Event Types Example</h2>
      <div id = "box" on-track = "myClick">{{track_message}}</div>
   </template>
   
   <script>
      Polymer ({
         is: 'gesture-event', myClick: function(e) {
            switch(e.detail.state) {
               case 'start':
               this.track_message = 'Tracking event started...';
               break;
               case 'track':
                  this.track_message = 'Tracking event is in progress... ' +
                  e.detail.x + ', ' + e.detail.y;
               break;
               case 'end':
                  this.track_message = 'Tracking event ended...';
               break;
            }
         }
      });
   </script>
</dom-module>

उत्पादन

पिछले उदाहरण में दिखाए गए अनुसार एप्लिकेशन चलाएं और नेविगेट करें http://127.0.0.1:8081/। अब तत्व में माउस को खींचना शुरू करें, यह निम्न स्क्रीनशॉट में दिखाए अनुसार राज्य को प्रदर्शित करेगा।

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

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

पॉलिमर एक तत्व के गुणों पर परिवर्तनों को देखने की अनुमति देता है जैसे कि विभिन्न क्रियाएं

  • Observers - जब भी डेटा बदलता है तो यह कॉलबैक को आमंत्रित करता है।

  • Computed Properties - यह अन्य गुणों के आधार पर आभासी गुणों की गणना करता है, और जब भी इनपुट डेटा बदलता है, तब उन्हें पुन: गणना करता है।

  • Data Bindings - यह जब भी डेटा बदलता है, एनोटेशन का उपयोग करके डोम नोड के गुणों, विशेषताओं या पाठ सामग्री को अपडेट करता है।

डेटा पथ

Pathडेटा सिस्टम में एक स्ट्रिंग है, जो एक गुंजाइश के सापेक्ष एक संपत्ति या एक उप-संपत्ति प्रदान करता है। गुंजाइश एक मेजबान तत्व हो सकती है। डेटा बाइंडिंग का उपयोग करके पथों को विभिन्न तत्वों से जोड़ा जा सकता है। डेटा परिवर्तन को एक तत्व से दूसरे में ले जाया जा सकता है, यदि तत्व डेटा बाइंडिंग से जुड़े हैं।

उदाहरण

<dom-module id = "my-profile">
   <template>
      . . .
      <address-card address="{{myAddress}}"></address-card>
   </template>
   . . .
</dom-module>

उपरोक्त दो पथ (मेरा-प्रोफ़ाइल और पता-कार्ड) को डेटा बाइंडिंग के साथ जोड़ा जा सकता है, यदि <एड्रेस-कार्ड> <my-profile> तत्व के स्थानीय DOM में है।

Polymer.js में विशेष प्रकार के पथ खंड निम्नलिखित हैं -

  • वाइल्ड कार्ड (*) वर्ण का उपयोग एक पथ के अंतिम खंड के रूप में किया जा सकता है।

  • ऐरे म्यूटेशन को एक पथ में अंतिम खंड के रूप में स्ट्रिंग स्पाइस को रखकर एक दिए गए एरे में प्रदर्शित किया जा सकता है।

  • सरणी पथ पथ किसी आइटम को किसी सरणी में इंगित करता है और संख्यात्मक पथ खंड एक सरणी सूचकांक निर्दिष्ट करता है।

डेटा पथ में, प्रत्येक पथ खंड एक संपत्ति का नाम है और उनमें दो प्रकार के पथ शामिल हैं -

  • पथ खंडों को डॉट्स द्वारा अलग किया गया। उदाहरण के लिए: "apple.grapes.orange"।

  • तार की एक सरणी में, प्रत्येक सरणी तत्व या तो एक पथ खंड या बिंदीदार पथ है। उदाहरण के लिए: ["सेब", "अंगूर", "नारंगी"], ["सेब। अंगूर", "नारंगी"]।

डाटा प्रवाह

उदाहरण

निम्न उदाहरण डेटा प्रवाह के दो-तरफ़ा बाध्यकारी को निर्दिष्ट करता है। एक index.html फ़ाइल बनाएँ और उसमें निम्न कोड जोड़ें।

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "my-element.html">
   </head>
   
   <body>
      <my-element></my-element>
   </body>
</html>

अब my-element.html नामक एक अन्य फ़ाइल बनाएँ और निम्नलिखित कोड शामिल करें।

<link rel = "import" href = "bower_components/polymer/polymer-element.html">
<link rel = "import" href = "prop-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "my-element">
   <template>
      <prop-element my-prop="{{demoProp}}"></prop-element>
      <p>
         Present value: <span>{{demoProp}}</span>
      </p>
   </template>
   
   <script>
      Polymer ({
         is: "my-element", properties: {
            demoProp: String
         }
      });
   </script>
</dom-module>

इसके बाद, Prop-element.html नामक एक और फ़ाइल बनाएँ और निम्नलिखित कोड जोड़ें।

//it specifies the start of an element's local DOM
<dom-module id = "prop-element">
   <template>
      <button on-click = "onClickFunc">Change value</button>
   </template>
   
   <script>
      Polymer ({
         is: "prop-element", properties: {
            myProp: {
               type: String,
               notify: true,
               readOnly: true,
               value: 'This is initial value...'
            }
         },
         onClickFunc: function(){
            this._setMyProp('This is new value after clicking the button...');
         }
      });
   </script>
</dom-module>

उत्पादन

एप्लिकेशन को पिछले अध्यायों में दिखाए अनुसार चलाएँ, और नेविगेट करें http://127.0.0.1:8081/। निम्नलिखित उत्पादन होगा।

बटन पर क्लिक करने के बाद, यह निम्न स्क्रीनशॉट में दिखाए गए मान को बदल देगा।

दो रास्तों को जोड़ना

आप दो रास्तों को लिंकपाथ विधि का उपयोग करके एक ही वस्तु से जोड़ सकते हैं और तत्वों के बीच परिवर्तन उत्पन्न करने के लिए डेटा बाइंडिंग का उपयोग करने की आवश्यकता होती है।

उदाहरण

linkPaths('myTeam', 'players.5');

पथ लिंकेज को अनलिंकपैथ्स विधि का उपयोग करके हटाया जा सकता है जैसा कि नीचे दिखाया गया है -

unlinkPaths('myTeam');

प्रेक्षकों

तत्व के डेटा में होने वाले अवलोकन परिवर्तन, पर्यवेक्षकों के रूप में जाना जाने वाले तरीकों का आह्वान करते हैं। निम्नलिखित पर्यवेक्षकों के प्रकार हैं।

  • एक ही संपत्ति का निरीक्षण करने के लिए सरल पर्यवेक्षकों का उपयोग किया जाता है।

  • जटिल पर्यवेक्षकों का उपयोग एक से अधिक संपत्ति या पथ का निरीक्षण करने के लिए किया जाता है।

अनिवार्य तथ्य

डेटा बाइंडिंग का उपयोग उसके स्थानीय DOM में होस्ट तत्व से गुण या तत्व की विशेषता को जोड़ने के लिए किया जा सकता है। निम्नलिखित कोड में दिखाए अनुसार DOM बंधन में एनोटेशन जोड़कर डेटा बाइंडिंग बनाई जा सकती है।

<dom-module id = "myhost-element">
   <template>
      <target-element target-property = "{{myhostProperty}}"></target-element>
   </template>
</dom-module>

स्थानीय DOM टेम्पलेट में डेटा बाइंडिंग की शारीरिक रचना निम्न की तरह दिखती है -

property-name=annotation-or-compound-binding

या

attribute-name$=annotation-or-compound-binding

बाइंडिंग का बायाँ भाग लक्ष्य संपत्ति या विशेषता को निर्दिष्ट करता है, जबकि बाइंडिंग का दाहिना भाग बाइंडिंग एनोटेशन या कम्पाउंड बाइंडिंग को निर्दिष्ट करता है। बाइंडिंग एनोटेशन में पाठ डबल कर्ली ब्रैकेट ({{}}) या डबल स्क्वायर ब्रैकेट ([[]]) परिसीमन द्वारा संलग्न हैं और यौगिक बाइंडिंग में एक या अधिक स्ट्रिंग शाब्दिक बाइंडिंग एनोटेशन शामिल हैं।

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

  • Template Repeater - सरणी में प्रत्येक आइटम के लिए टेम्पलेट की सामग्री का एक उदाहरण बनाया जा सकता है।

  • Array Selector - यह संरचित डेटा की एक सरणी के लिए चयन स्थिति प्रदान करता है।

  • Conditional Template - आप सामग्री की पहचान कर सकते हैं, अगर हालत सच है।

  • Auto-binding Template - यह बहुलक तत्व के बाहर डेटा बाध्यकारी को निर्दिष्ट करता है।

DOM ट्री एक डोम-परिवर्तन इवेंट को चलाता है, यदि सहायक तत्व DOM ट्री को अपडेट करते हैं। कभी-कभी, आप मॉडल डेटा को बदलकर डोम के साथ बातचीत कर सकते हैं, न कि बनाए गए नोड्स के साथ बातचीत करके। इसलिए, आप नोड्स को सीधे एक्सेस करने के लिए डोम-परिवर्तन इवेंट का उपयोग कर सकते हैं।