पॉलिमर - शैडो डोम और स्टाइलिंग

शैडो डोम, भवन घटकों के लिए उपयोग किए जाने वाले 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/। निम्नलिखित उत्पादन होगा।

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

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

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

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

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