डी 3.जेएस - संग्रह एपीआई

एक संग्रह केवल एक वस्तु है जो कई तत्वों को एक इकाई में समूहित करता है। इसे एक कंटेनर के रूप में भी कहा जाता है। यह अध्याय संग्रह एपीआई के बारे में विस्तार से बताता है।

API को कॉन्फ़िगर करना

आप निम्न स्क्रिप्ट का उपयोग करके एपीआई को कॉन्फ़िगर कर सकते हैं।

<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script>

</script>

संग्रह एपीआई तरीके

संग्रह API में ऑब्जेक्ट्स, मैप्स, सेट्स और घोंसले होते हैं। निम्नलिखित सबसे आम तौर पर उपयोग किए जाने वाले संग्रह एपीआई तरीके हैं।

  • ऑब्जेक्ट्स API
  • मैप्स एपीआई
  • एपीआई सेट करता है
  • घोंसला एपीआई

आइए हम इनमें से प्रत्येक एपीआई के बारे में विस्तार से जाने।

ऑब्जेक्ट्स API

ऑब्जेक्ट API महत्वपूर्ण डेटा प्रकारों में से एक है। यह निम्नलिखित विधियों का समर्थन करता है -

  • d3.keys(object) - इस विधि में ऑब्जेक्ट प्रॉपर्टी कीज़ होती हैं और प्रॉपर्टी नामों की एक सरणी लौटाती है।

  • d3.values(object) - इस पद्धति में ऑब्जेक्ट वैल्यू शामिल है और संपत्ति मूल्यों की एक सरणी लौटाती है।

  • d3.entries(object)- इस विधि का उपयोग किसी सरणी को निर्दिष्ट ऑब्जेक्ट की कुंजी और मान दोनों को वापस करने के लिए किया जाता है। प्रत्येक प्रविष्टि एक कुंजी और मूल्य के साथ एक वस्तु है।

Example - आइए हम निम्नलिखित कोड पर विचार करें।

d3.entries({one: 1})

यहां, कुंजी एक है और मूल्य 1 है।

Example - एक वेबपेज बनाएं objects.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = {"jan": 1, "Feb": 2, "mar": 3, "apr": 4};
         console.log(d3.keys(month));
         console.log(d3.values(month));
         console.log(d3.entries(month));
      </script>
   </body>
</html>

अब, ब्राउज़र का अनुरोध करें और आप निम्नलिखित प्रतिक्रिया देखेंगे।

मैप्स एपीआई

एक मानचित्र में कुंजी और मूल्य जोड़े के आधार पर मूल्य शामिल हैं। प्रत्येक कुंजी और मूल्य जोड़ी को एक प्रविष्टि के रूप में जाना जाता है। एक मानचित्र में केवल अनन्य कुंजियाँ होती हैं। कुंजी के आधार पर तत्वों को खोजना, अपडेट या हटाना उपयोगी है। आइए हम विभिन्न मैप्स एपीआई विधियों के बारे में विस्तार से जानते हैं।

  • d3.map([object[, key]])- इस विधि का उपयोग एक नया नक्शा बनाने के लिए किया जाता है। ऑब्जेक्ट का उपयोग सभी गणना योग्य गुणों को कॉपी करने के लिए किया जाता है।

  • map.has(key) - इस पद्धति का उपयोग यह जांचने के लिए किया जाता है कि मानचित्र में निर्दिष्ट कुंजी स्ट्रिंग के लिए प्रविष्टि है या नहीं।

  • map.get(key) - इस विधि का उपयोग निर्दिष्ट कुंजी स्ट्रिंग के लिए मान लौटाने के लिए किया जाता है।

  • map.set(key, value)- इस विधि का उपयोग निर्दिष्ट कुंजी स्ट्रिंग के लिए मान सेट करने के लिए किया जाता है। यदि मानचित्र में पहले एक ही कुंजी स्ट्रिंग के लिए एक प्रविष्टि थी, तो पुराने प्रविष्टि को नए मूल्य के साथ बदल दिया जाता है।

  • map.remove(key)- इसका उपयोग मैप एंट्री को हटाने के लिए किया जाता है। यदि कुंजी निर्दिष्ट नहीं है, तो यह गलत है।

  • map.clear() - इस नक्शे से सभी प्रविष्टियाँ निकालता है।

  • map.keys() - इस नक्शे में हर प्रविष्टि के लिए स्ट्रिंग कुंजियों की एक सरणी देता है।

  • map.values() - इस नक्शे में हर प्रविष्टि के लिए मूल्यों की एक सरणी देता है।

  • map.entries() - इस नक्शे में प्रत्येक प्रविष्टि के लिए कुंजी-मूल्य वस्तुओं की एक सरणी देता है।

  • (x) map.each(function) - इस पद्धति का उपयोग मानचित्र में प्रत्येक प्रविष्टि के लिए निर्दिष्ट फ़ंक्शन को कॉल करने के लिए किया जाता है।

  • (xi) map.empty() - अगर यह नक्शा शून्य प्रविष्टियाँ हैं तो ही और अगर रिटर्न सही है।

  • (xii) map.size() - इस नक्शे में प्रविष्टियों की संख्या लौटाता है।

Example - एक वेबपेज बनाएं maps.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = d3.map([{name: "jan"}, {name: "feb"}], 
            function(d) { return d.name; });
         console.log(month.get("jan")); // {"name": "jan"}
         console.log(month.get("apr")); // undefined
         console.log(month.has("feb")); // true
         
         var map =  d3.map().set("fruit", "mango");
         console.log(map.get("fruit")); // mango
         console.log(map.remove("fruit")); // remove key and return true.
         console.log(map.size());    // size is 0 because key removed.
         console.log(map.empty());   // true
      </script>
   </body>
</html>

अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित प्रतिक्रिया देखेंगे।

इसी तरह, आप अन्य ऑपरेशन भी कर सकते हैं।

एपीआई सेट करता है

एक सेट एक संग्रह है जिसमें डुप्लिकेट तत्व नहीं हो सकते हैं। यह गणितीय सेट अमूर्त मॉडल है। आइए हम विभिन्न सेट एपीआई विधियों के बारे में विस्तार से जानते हैं।

  • d3.set([array[, accessor]])- इस विधि का उपयोग एक नया सेट बनाने के लिए किया जाता है। ऐरे का उपयोग स्ट्रिंग मान जोड़ने के लिए किया जाता है। एक एक्सेसर वैकल्पिक है।

  • set.has(value) - इस विधि का उपयोग यह जांचने के लिए किया जाता है कि सेट में निर्दिष्ट मान स्ट्रिंग के लिए प्रविष्टि है या नहीं।

  • set.add(value) - इसका उपयोग सेट पर निर्दिष्ट मान स्ट्रिंग जोड़ने के लिए किया जाता है।

  • set.remove(value) - इसका उपयोग उस सेट को हटाने के लिए किया जाता है जिसमें निर्दिष्ट मान स्ट्रिंग होता है।

  • set.clear() - इस सेट से सभी मान निकालता है।

  • set.values() - इस विधि का उपयोग सेट पर मानों की एक सरणी वापस करने के लिए किया जाता है।

  • set.empty() - अगर यह सेट शून्य मान है और केवल तभी लौटाता है।

  • set.size() - इस सेट में मानों की संख्या लौटाता है।

Example - एक वेबपेज बनाएं sets.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var fruits =  d3.set().add("mango")
          .add("apple").add("orange");
         console.log(fruits.has("grapes")); // return false.
         console.log(fruits.remove("apple")); //true
         console.log(fruits.size());    // size is 2
         console.log(fruits.empty());   // true
      </script>
   </body>
</html>

अब, ब्राउज़र का अनुरोध करें और हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

इसी तरह, हम अन्य ऑपरेशन भी कर सकते हैं।

घोंसला एपीआई

नेस्टिंग एपीआई में सरणी में तत्व होते हैं और एक पदानुक्रमित पेड़ संरचना में प्रदर्शन करते हैं। आइए हम विभिन्न घोंसले एपीआई तरीकों के बारे में विस्तार से जानते हैं।

  • d3.nest() - इस विधि का उपयोग एक नया घोंसला बनाने के लिए किया जाता है।

  • nest.key(key)- इस विधि का उपयोग किसी नए मुख्य कार्य को आरंभ करने के लिए किया जाता है। इस फ़ंक्शन का उपयोग समूह में प्रत्येक तत्व को इनपुट एरे और रिटर्न एलीमेंट्स में शामिल करने के लिए किया जाता है।

  • nest.sortKeys(comparator)- इस विधि का उपयोग किसी निर्दिष्ट तुलनित्र में चाबियाँ छाँटने के लिए किया जाता है। फ़ंक्शन को d3.ascending या d3.descending के रूप में परिभाषित किया गया है।

  • nest.sortValues(comparator)- इस विधि का उपयोग निर्दिष्ट तुलनित्र में मानों को क्रमबद्ध करने के लिए किया जाता है। तुलनित्र फ़ंक्शन पत्ती तत्वों को सॉर्ट करता है।

  • nest.map(array)- इस पद्धति का उपयोग निर्दिष्ट सरणी को लागू करने और नेस्टेड मैप को वापस करने में किया जाता है। लौटे नक्शे में प्रत्येक प्रविष्टि पहले कुंजी फ़ंक्शन द्वारा लौटाए गए एक अलग कुंजी मान से मेल खाती है। प्रवेश मूल्य पंजीकृत प्रमुख कार्यों की संख्या पर निर्भर करता है।

  • nest.object(array) - इस विधि का उपयोग नेस्ट ऑपरेटर को निर्दिष्ट एरे में लागू करने और नेस्टेड ऑब्जेक्ट को वापस करने के लिए किया जाता है।

  • nest.entries(array) - इस पद्धति का उपयोग घोंसला ऑपरेटर को निर्दिष्ट सरणी में लागू करने और कुंजी-मान प्रविष्टियों की एक सरणी वापस करने के लिए किया जाता है।

एक साधारण वेबपेज पर विचार करें nest.html उपरोक्त चर्चा करने के लिए घोंसले के तरीकों का प्रदर्शन करें।

Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 Nest API</h3>
      <script>
         var data = [
            {
               "color" : "red",
               "key" : 1
            },
            {
               "color" : "green",
               "key" : 2
            },
            {
               "color" : "blue",
               "key" : 75
            }
         ]
         var nest =  d3.nest()
            .key(function (d) { return d.color; })
            .entries(data)console.log(nest);
         var filter = nest.filter(function (d) { return d.key = = = 'red' })
         console.log(filter);
      </script>
   </body>
</html>

अब, एक ब्राउज़र में परिणाम की जाँच करें और हम निम्नलिखित परिणाम देखेंगे।

Array[3]
0: Object
1: Object
2: Object
length: 3
__proto__: Array[0]

Array[1]
0: Object
length: 1
__proto__: Array[0]