डी 3.जेएस - डाटा जॉइन

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

डेटा जॉइन क्या है?

डेटा जुड़ाव हमें मौजूदा HTML दस्तावेज़ में सेट किए गए डेटा के आधार पर तत्वों (HTML तत्व और साथ ही एम्बेडेड SVG तत्वों) को इंजेक्ट, संशोधित और हटाने में सक्षम बनाता है। डिफ़ॉल्ट रूप से, डेटा सेट में प्रत्येक डेटा आइटम दस्तावेज़ में एक तत्व (चित्रमय) से मेल खाता है।

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

डेटा कैसे काम करता है?

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

[10, 20, 30, 25, 15]

डेटा सेट में पांच आइटम हैं और इसलिए, इसे दस्तावेज़ के पांच तत्वों में मैप किया जा सकता है। हमें इसे मैप करते हैंli चयनकर्ता के चयन (एल) विधि और डेटा जुड़ने के डेटा () पद्धति का उपयोग करके निम्नलिखित दस्तावेज़ का तत्व।

एचटीएमएल

<ul id = "list">
   <li><li>
   <li></li>
</ul>

D3.js कोड

d3.select("#list").selectAll("li").data([10, 20, 30, 25, 15]);

अब, दस्तावेज़ में पाँच आभासी तत्व हैं। पहले दो आभासी तत्व दो हैंli दस्तावेज में परिभाषित तत्व जैसा कि नीचे दिखाया गया है।

1. li - 10
2. li - 20

हम सभी चयनकर्ता के तत्व को संशोधित करने के तरीकों का उपयोग कर सकते हैं attr(), style(), text()आदि, पहले दो के लिए li जैसा की नीचे दिखाया गया।

d3.select("#list").selectAll("li")
   .data([10, 20, 30, 25, 15])
   .text(function(d) { return d; });

पाठ को प्राप्त करने के लिए पाठ () विधि में फ़ंक्शन का उपयोग किया जाता है liतत्वों ने डेटा मैप किया। यहाँ,d पहले 10 के लिए प्रतिनिधित्व करते हैं li तत्व और 20 सेकंड के लिए li तत्व।

अगले तीन तत्वों को किसी भी तत्व में मैप किया जा सकता है और यह डेटा जॉइन के एंटर () और चयनकर्ता के एपेंड () विधि का उपयोग करके किया जा सकता है। दर्ज () विधि शेष डेटा (जो मौजूदा तत्वों के लिए मैप नहीं की गई है) तक पहुंच प्रदान करती है और संबंधित डेटा से एक नया तत्व बनाने के लिए ऐपेंड () विधि का उपयोग किया जाता है। हमें बनाने दोliशेष डेटा आइटम के लिए भी। डेटा मैप इस प्रकार है -

3. li - 30
4. li - 25
5. li - 15

एक नया तत्व बनाने के लिए कोड निम्नानुसार है -

d3.select("#list").selectAll("li")
   .data([10, 20, 30, 25, 15])
   .text(function(d) { return "This is pre-existing element and the value is " + d; })
   .enter()
   .append("li")
   .text(function(d) 
      { return "This is dynamically created element and the value is " + d; });

डेटा जॉइन एक और विधि प्रदान करता है जिसे बुलाया जाता है exit() method नीचे दिखाए गए डेटा सेट से डेटा आइटम को गतिशील रूप से संसाधित करने के लिए।

d3.selectAll("li")
   .data([10, 20, 30, 15])
   .exit()
   .remove()

यहां, हमने डेटा सेट और उसके संबंधित ली से चौथे आइटम को बाहर निकलने () और हटाने () के तरीकों का उपयोग किया है।

पूरा कोड इस प्रकार है -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         body { font-family: Arial; }
      </style>
   </head>

   <body>
      <ul id = "list">
         <li></li>
         <li></li>
      </ul>
        
      <input type = "button" name = "remove" value = "Remove fourth value" 
         onclick = "javascript:remove()" />
      
      <script>
         d3.select("#list").selectAll("li")
            .data([10, 20, 30, 25, 15])
            .text(function(d) 
               { return "This is pre-existing element and the value is " + d; })
            .enter()
            .append("li")
            .text(function(d) 
               { return "This is dynamically created element and the value is " + d; });
             
         function remove() {
            d3.selectAll("li")
            .data([10, 20, 30, 15])
            .exit()
            .remove()
         }
      </script>
   </body>
</html>

उपरोक्त कोड का परिणाम निम्नानुसार होगा -