डी 3.जेएस - चयन

चयन D3.js. में मुख्य अवधारणाओं में से एक है यह CSS चयनकर्ताओं पर आधारित है। यह हमें एक वेबपेज में एक या अधिक तत्वों का चयन करने की अनुमति देता है। इसके अलावा, यह हमें पूर्व-परिभाषित डेटासेट के संबंध में तत्वों को संशोधित करने, जोड़ने या हटाने की अनुमति देता है। इस अध्याय में, हम देखेंगे कि डेटा विज़ुअलाइज़ेशन बनाने के लिए चयन का उपयोग कैसे करें।

D3.js निम्नलिखित दो विधियों का उपयोग करके HTML पृष्ठ से तत्वों का चयन करने में मदद करता है -

  • select()- दिए गए CSS चयनकर्ता के मिलान से केवल एक DOM तत्व का चयन करता है। यदि दिए गए CSS चयनकर्ता के लिए एक से अधिक तत्व हैं, तो यह केवल पहले वाले का चयन करता है।

  • selectAll()- दिए गए CSS चयनकर्ता से मेल करके सभी DOM तत्वों का चयन करता है। यदि आप jQuery के साथ तत्वों का चयन करने से परिचित हैं, तो D3.js चयनकर्ता लगभग समान हैं।

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

चयन () विधि

चयन () विधि सीएसएस चयनकर्ताओं के आधार पर HTML तत्व का चयन करती है। CSS चयनकर्ताओं में, आप निम्न तीन तरीकों से HTML- तत्वों को परिभाषित और उपयोग कर सकते हैं -

  • HTML तत्व का टैग (जैसे div, h1, p, span, आदि)
  • एक HTML तत्व का वर्ग नाम
  • एक HTML तत्व की आईडी

आइए इसे उदाहरणों के साथ कार्रवाई में देखें।

टैग द्वारा चयन

आप TAG का उपयोग करके HTML तत्वों का चयन कर सकते हैं। निम्नलिखित सिंटैक्स का उपयोग "div" टैग तत्वों को चुनने के लिए किया जाता है,

d3.select(“div”)

Example - एक पेज "select_by_tag.html" बनाएं और निम्नलिखित परिवर्तन जोड़ें,

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

   <body>
      <div>
         Hello World!    
      </div>
      
      <script>
         alert(d3.select("div").text());
      </script>
   </body>
</html>

ब्राउज़र के माध्यम से वेबपेज का अनुरोध करके, आप स्क्रीन पर निम्न आउटपुट देखेंगे -

वर्ग नाम से चयन

CSS कक्षाओं का उपयोग करके स्टाइल किए गए HTML तत्वों को निम्नलिखित सिंटैक्स का उपयोग करके चुना जा सकता है।

d3.select(“.<class name>”)

एक वेबपेज "select_by_class.html" बनाएं और निम्नलिखित बदलाव जोड़ें -

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         alert(d3.select(".myclass").text());
      </script>
   </body>
</html>

ब्राउज़र के माध्यम से वेबपेज का अनुरोध करके, आप स्क्रीन पर निम्न आउटपुट देखेंगे -

आईडी द्वारा चयन

एक HTML पेज के प्रत्येक तत्व में एक विशिष्ट आईडी होनी चाहिए। हम नीचे निर्दिष्ट के रूप में चयन () विधि का उपयोग करके एक तत्व की इस अनूठी आईडी का उपयोग कर सकते हैं।

d3.select(“#<id of an element>”)

एक वेबपेज "select_by_id.html" बनाएं और निम्नलिखित बदलाव जोड़ें।

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

   <body>
      <div id = "hello">
         Hello World!
      </div>
      
      <script>
         alert(d3.select("#hello").text());
      </script>
   </body>
</html>

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

डोम तत्व जोड़ना

D3.js चयन प्रदान करता है append() और यह text()मौजूदा HTML दस्तावेजों में नए तत्वों को जोड़ने के तरीके। यह खंड विस्तार से DOM तत्वों को जोड़ने के बारे में बताता है।

परिशिष्ट () विधि

अपेंड () पद्धति वर्तमान चयन में तत्व के अंतिम बच्चे के रूप में एक नए तत्व को जोड़ती है। यह विधि तत्वों की शैली, उनकी विशेषताओं, गुणों, HTML और पाठ सामग्री को भी संशोधित कर सकती है।

एक वेबपेज "select_and_append.html" बनाएं और निम्नलिखित बदलाव जोड़ें -

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span");
      </script>
   </body>
</html>

ब्राउज़र के माध्यम से वेबपृष्ठ का अनुरोध करते हुए, आप स्क्रीन पर निम्न आउटपुट देख सकते हैं,

यहाँ, परिशिष्ट () विधि div टैग के अंदर एक नया टैग अवधि जोड़ता है जैसा कि नीचे दिखाया गया है -

<div class = "myclass">
   Hello World!<span></span>
</div>

पाठ () विधि

पाठ () विधि का उपयोग चयनित / संलग्न तत्वों की सामग्री को सेट करने के लिए किया जाता है। हमें ऊपर दिए गए उदाहरण को बदलने और पाठ () विधि को नीचे दिखाए अनुसार जोड़ें।

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span").text("from D3.js");
      </script>
   </body>
</html>

अब वेबपेज को रिफ्रेश करें और आपको निम्न प्रतिक्रिया दिखाई देगी।

यहाँ, उपरोक्त लिपि एक जंजीर संचालन करती है। D3.js चालाकी से एक तकनीक का उपयोग करता है जिसे कहा जाता हैchain syntax, जिसे आप पहचान सकते हैं jQuery। पीरियड्स के साथ तरीकों का पीछा करते हुए, आप कोड की एक पंक्ति में कई क्रियाएं कर सकते हैं। यह तेज और आसान है। उसी स्क्रिप्ट को बिना चेन सिंटैक्स के भी एक्सेस किया जा सकता है जैसा कि नीचे दिखाया गया है।

var body = d3.select("div.myclass");
var span = body.append("span");
span.text("from D3.js");

संशोधित करने वाले तत्व

D3.js विभिन्न तरीकों प्रदान करता है, html(), attr() तथा style()चयनित तत्वों की सामग्री और शैली को संशोधित करने के लिए। आइए देखें कि इस अध्याय में संशोधित तरीकों का उपयोग कैसे किया जाए।

HTML () विधि

HTML () विधि का उपयोग चयनित / संलग्न तत्वों के HTML सामग्री को सेट करने के लिए किया जाता है।

एक वेबपेज "select_and_add_html.html" बनाएं और निम्नलिखित कोड जोड़ें।

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").html("Hello World! <span>from D3.js</span>");
      </script>
   </body>
</html>

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

Attr () विधि

एटर () विधि का उपयोग चयनित तत्वों की विशेषता को जोड़ने या अपडेट करने के लिए किया जाता है। एक वेबपेज "select_and_modify.html" बनाएं और निम्नलिखित कोड जोड़ें।

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

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

शैली () विधि

शैली () विधि का उपयोग चयनित तत्वों की शैली गुण सेट करने के लिए किया जाता है। एक वेबपेज "select_and_style.html" बनाएं और निम्नलिखित कोड जोड़ें।

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").style("color", "red");
      </script>
   </body>
</html>

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

श्रेणीबद्ध () विधि

एक HTML तत्व के "वर्ग" विशेषता को सेट करने के लिए विशेष रूप से वर्गीकृत () विधि का उपयोग किया जाता है। चूंकि, एक एकल HTML तत्व में कई वर्ग हो सकते हैं; HTML तत्व को एक कक्षा प्रदान करते समय हमें सावधान रहने की आवश्यकता है। यह विधि जानती है कि एक तत्व पर एक या कई वर्गों को कैसे संभालना है, और यह प्रदर्शन करने वाला होगा।

  • Add class- एक वर्ग जोड़ने के लिए, वर्गीकृत विधि का दूसरा पैरामीटर सही पर सेट होना चाहिए। यह नीचे परिभाषित किया गया है -

d3.select(".myclass").classed("myanotherclass", true);
  • Remove class- एक कक्षा को हटाने के लिए, वर्गीकृत विधि का दूसरा पैरामीटर गलत पर सेट होना चाहिए। यह नीचे परिभाषित किया गया है -

d3.select(".myclass").classed("myanotherclass", false);
  • Check class- एक वर्ग के अस्तित्व की जांच करने के लिए, बस दूसरे पैरामीटर को छोड़ दें और उस वर्ग के नाम को पास करें जिसे आप क्वेरी कर रहे हैं। यह सच है, अगर यह मौजूद है, तो झूठ होगा, अगर यह नहीं है।

d3.select(".myclass").classed("myanotherclass");

यह सच है, अगर चयन में किसी भी तत्व वर्ग है। उपयोगd3.select एकल तत्व चयन के लिए।

  • Toggle class - किसी वर्ग को विपरीत स्थिति में ले जाने के लिए - इसे हटा दें यदि यह पहले से मौजूद है, तो इसे जोड़ें यदि यह अभी तक मौजूद नहीं है - तो आप निम्न में से एक कर सकते हैं।

    किसी एकल तत्व के लिए, कोड नीचे दिखाया गया है -

var element = d3.select(".myclass")
element.classed("myanotherclass", !oneBar.classed("myanotherclass"));

SelectAll () विधि

HTML दस्तावेज़ में कई तत्वों का चयन करने के लिए SelectAll () विधि का उपयोग किया जाता है। चयन विधि पहले तत्व का चयन करती है, लेकिन चयन विधि सभी तत्वों का चयन करती है जो विशिष्ट चयनकर्ता स्ट्रिंग से मेल खाते हैं। यदि चयन में कोई भी मेल नहीं खाता है, तो यह एक खाली चयन देता है। हम सभी संशोधित संशोधित तरीकों की श्रृंखला बना सकते हैं,append(), html(), text(), attr(), style(), classed(),आदि, SelectAll () विधि में भी। इस मामले में, विधियाँ सभी मिलान तत्वों को प्रभावित करेंगी। हमें एक नया वेबपेज "select_multiple.html" बनाकर समझें और निम्नलिखित स्क्रिप्ट जोड़ें -

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

   <body>
      <h2 class = "myclass">Message</h2>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.selectAll(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

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

यहाँ, attr () विधि दोनों पर लागू होती है div तथा h2 tag और दोनों टैग में पाठ का रंग बदलकर लाल हो जाता है।