पॉलिमर - डेटा सिस्टम
पॉलिमर विभिन्न क्रियाओं द्वारा किसी तत्व के गुणों पर परिवर्तनों को देखने की अनुमति देता है जैसे कि -
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 ट्री को अपडेट करते हैं। कभी-कभी, आप मॉडल डेटा को बदलकर डोम के साथ बातचीत कर सकते हैं, निर्मित नोड्स के साथ बातचीत करके नहीं। इसलिए, आप नोड्स को सीधे एक्सेस करने के लिए डोम-परिवर्तन इवेंट का उपयोग कर सकते हैं।