डी 3.जेएस - त्वरित गाइड

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

डेटा विज़ुअलाइज़ेशन हमें अपनी अंतर्दृष्टि को जल्दी और प्रभावी ढंग से संवाद करने में मदद करता है। किसी भी प्रकार का डेटा, जिसे एक विज़ुअलाइज़ेशन द्वारा दर्शाया गया है, उपयोगकर्ताओं को डेटा की तुलना करने, विश्लेषणात्मक रिपोर्ट उत्पन्न करने, पैटर्न को समझने और इस तरह उन्हें निर्णय लेने में मदद करता है। डेटा विज़ुअलाइज़ेशन इंटरैक्टिव हो सकता है, ताकि उपयोगकर्ता चार्ट में विशिष्ट डेटा का विश्लेषण करें। खैर, डेटा विज़ुअलाइज़ेशन को विभिन्न जावास्क्रिप्ट फ्रेमवर्क का उपयोग करके नियमित वेबसाइटों और यहां तक ​​कि मोबाइल एप्लिकेशन में विकसित और एकीकृत किया जा सकता है।

D3.js क्या है?

D3.js एक जावास्क्रिप्ट लाइब्रेरी है जिसका उपयोग ब्राउज़र में इंटरैक्टिव विज़ुअलाइज़ेशन बनाने के लिए किया जाता है। D3.js लाइब्रेरी हमें डेटा सेट के संदर्भ में एक वेबपेज के तत्वों में हेरफेर करने की अनुमति देता है। ये तत्व हो सकते हैंHTML, SVG, या Canvas elementsऔर डेटा सेट की सामग्री के अनुसार शुरू, हटाया या संपादित किया जा सकता है। यह DOM ऑब्जेक्ट्स में हेरफेर करने के लिए एक लाइब्रेरी है। D3.js डेटा अन्वेषण में एक मूल्यवान सहायता हो सकती है, यह आपको अपने डेटा के प्रतिनिधित्व पर नियंत्रण देता है और आपको अन्तरक्रियाशीलता जोड़ने देता है।

हमें D3.js की आवश्यकता क्यों है?

अन्य पुस्तकालयों की तुलना में D3.js प्रमुख ढांचे में से एक है। ऐसा इसलिए है क्योंकि यह वेब पर काम करता है और इसके डेटा विज़ुअलाइज़ेशन बराबर उत्कृष्टता है। एक और कारण यह अच्छी तरह से काम किया है इसकी लचीलापन के कारण है। चूंकि यह मौजूदा वेब प्रौद्योगिकियों के साथ सहजता से काम करता है और दस्तावेज़ ऑब्जेक्ट मॉडल के किसी भी हिस्से में हेरफेर कर सकता है, यह उतना ही लचीला हैClient Side Web Technology Stack(HTML, CSS और SVG)। इसके पास एक महान सामुदायिक समर्थन है और यह सीखना आसान है।

D3.js सुविधाएँ

डी 3.जेएस सर्वश्रेष्ठ डेटा विज़ुअलाइज़ेशन फ्रेमवर्क में से एक है और इसका उपयोग सरल और साथ ही जटिल विज़ुअलाइज़ेशन के साथ-साथ उपयोगकर्ता इंटरैक्शन और संक्रमण प्रभाव उत्पन्न करने के लिए किया जा सकता है। इसकी कुछ मुख्य विशेषताएं नीचे सूचीबद्ध हैं -

  • बेहद लचीला।
  • उपयोग में आसान और तेज।
  • बड़े डेटासेट का समर्थन करता है।
  • घोषणात्मक प्रोग्रामिंग।
  • कोड पुन: प्रयोज्य।
  • वक्र निर्माण कार्यों की एक विस्तृत विविधता है।
  • HTML पृष्ठ में एक तत्व या तत्वों के समूह के लिए सहयोगी डेटा।

D3.js लाभ

D3.js एक ओपन सोर्स प्रोजेक्ट है और बिना किसी प्लगइन के काम करता है। इसके लिए बहुत कम कोड की आवश्यकता होती है और निम्नलिखित लाभ के साथ आता है -

  • महान डेटा दृश्य।

  • यह मॉड्यूलर है। आप D3.js का एक छोटा सा टुकड़ा डाउनलोड कर सकते हैं, जिसे आप उपयोग करना चाहते हैं। हर बार पूरे पुस्तकालय को लोड करने की आवश्यकता नहीं है।

  • एक चार्टिंग घटक बनाने में आसान।

  • डोम हेरफेर।

अगले अध्याय में, हम समझेंगे कि हमारे सिस्टम पर D3.js कैसे स्थापित करें।

इस अध्याय में, हम सीखेंगे कि D3.js विकास पर्यावरण कैसे स्थापित किया जाए। शुरू करने से पहले, हमें निम्नलिखित घटकों की आवश्यकता है -

  • D3.js पुस्तकालय
  • Editor
  • वेब ब्राउज़र
  • वेब सर्वर

आइए हम विस्तार से एक-एक करके चरणों से गुजरते हैं।

D3.js लाइब्रेरी

डेटा विज़ुअलाइज़ेशन बनाने के लिए D3.js का उपयोग करने के लिए हमें अपने HTML वेबपेज में D3.js लाइब्रेरी को शामिल करना होगा। हम इसे निम्नलिखित दो तरीकों से कर सकते हैं -

  • अपने प्रोजेक्ट के फ़ोल्डर से D3.js लाइब्रेरी को शामिल करें।
  • CDN (सामग्री वितरण नेटवर्क) से D3.js पुस्तकालय शामिल करें।

डाउनलोड D3.js लाइब्रेरी

D3.js एक ओपन-सोर्स लाइब्रेरी है और लाइब्रेरी का सोर्स कोड वेब पर स्वतंत्र रूप से उपलब्ध है https://d3js.org/वेबसाइट। D3.js वेबसाइट पर जाएं और D3.js (d3.zip) का नवीनतम संस्करण डाउनलोड करें। अब तक, नवीनतम संस्करण 4.6.0 है।

डाउनलोड पूरा होने के बाद, फ़ाइल को अनज़िप करें और देखें d3.min.js। यह D3.js स्रोत कोड का छोटा संस्करण है। D3.min.js फ़ाइल को कॉपी करें और इसे अपने प्रोजेक्ट के रूट फ़ोल्डर या किसी अन्य फ़ोल्डर में पेस्ट करें, जहाँ आप सभी लाइब्रेरी फ़ाइलों को रखना चाहते हैं। नीचे दिखाए गए अनुसार अपने HTML पृष्ठ में d3.min.js फ़ाइल शामिल करें।

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

<!DOCTYPE html>
<html lang = "en">
   <head>
      <script src = "/path/to/d3.min.js"></script>
   </head>

   <body>
      <script>
         // write your d3 code here.. 
      </script>
   </body>
</html>

D3.js एक जावास्क्रिप्ट कोड है, इसलिए हमें "स्क्रिप्ट" टैग के भीतर अपने सभी डी 3 कोड लिखना चाहिए। हमें मौजूदा DOM तत्वों में हेरफेर करने की आवश्यकता हो सकती है, इसलिए "बॉडी" टैग के अंत से पहले डी 3 कोड लिखना उचित है।

सीडीएन से डी 3 लाइब्रेरी शामिल करें

हम सामग्री वितरण नेटवर्क (सीडीएन) से सीधे अपने एचटीएमएल पेज में इसे जोड़कर डी 3 की लाइब्रेरी का उपयोग कर सकते हैं। CDN सर्वरों का एक नेटवर्क है जहाँ फाइलों को होस्ट किया जाता है और एक उपयोगकर्ता को उनके भौगोलिक स्थान के आधार पर वितरित किया जाता है। यदि हम CDN का उपयोग करते हैं, तो हमें स्रोत कोड डाउनलोड करने की आवश्यकता नहीं है।

CD.N URL का उपयोग करके D3.js लाइब्रेरी को शामिल करें https://d3js.org/d3.v4.min.js नीचे दिखाए गए अनुसार हमारे पृष्ठ में।

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

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

   <body>
      <script>
         // write your d3 code here.. 
      </script>
   </body>
</html>

D3.js संपादक

हमें आपका कोड लिखना शुरू करने के लिए एक संपादक की आवश्यकता होगी। जावास्क्रिप्ट के लिए समर्थन के साथ कुछ महान आईडीई (एकीकृत विकास पर्यावरण) हैं -

  • विजुअल स्टूडियो कोड
  • WebStorm
  • Eclipse
  • उदात्त पाठ

ये आईडीई बुद्धिमान कोड पूरा करने के साथ-साथ आधुनिक जावास्क्रिप्ट फ्रेमवर्क में से कुछ का समर्थन करते हैं। यदि आपके पास फैंसी आईडीई नहीं है, तो आप हमेशा एक बुनियादी संपादक जैसे नोटपैड, VI आदि का उपयोग कर सकते हैं।

वेब ब्राउज़र

IE8 और लोअर को छोड़कर सभी ब्राउज़रों पर D3.js काम करता है।

वेब सर्वर

अधिकांश ब्राउज़र स्थानीय HTML फ़ाइल को सीधे स्थानीय फ़ाइल सिस्टम से सेवित करते हैं। हालांकि, बाहरी डेटा फ़ाइलों को लोड करने की बात आने पर कुछ प्रतिबंध हैं। इस ट्यूटोरियल के बाद के अध्यायों में, हम बाहरी फ़ाइलों से डेटा लोड करेंगेCSV तथा JSON। इसलिए, यह हमारे लिए आसान होगा, अगर हम शुरुआत से ही वेब सर्वर सेट करते हैं।

आप किसी भी वेब सर्वर का उपयोग कर सकते हैं, जिसके साथ आप सहज हैं - जैसे IIS, Apache, आदि।

आपका पृष्ठ देखना

ज्यादातर मामलों में, हम इसे देखने के लिए वेब ब्राउजर में आपकी HTML फाइल को खोल सकते हैं। हालांकि, बाहरी डेटा स्रोतों को लोड करते समय, स्थानीय वेब सर्वर को चलाने और सर्वर से अपने पृष्ठ को देखने के लिए अधिक विश्वसनीय है(http://localhost:8080)

D3.js के लिए एक खुला स्रोत जावास्क्रिप्ट पुस्तकालय है -

  • दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) का डेटा-चालित हेरफेर।
  • डेटा और आकृतियों के साथ काम करना।
  • रैखिक, पदानुक्रमित, नेटवर्क और भौगोलिक डेटा के लिए दृश्य तत्वों को बिछाना।
  • उपयोगकर्ता इंटरफ़ेस (UI) के बीच सहज बदलाव को सक्षम करना।
  • प्रभावी उपयोगकर्ता सहभागिता को सक्षम करना।

वेब मानक

इससे पहले कि हम विज़ुअलाइज़ेशन बनाने के लिए D3.js का उपयोग करना शुरू कर सकें, हमें वेब मानकों से परिचित होने की आवश्यकता है। निम्न वेब मानकों को अत्यधिक रूप से D3.js. में उपयोग किया जाता है

  • हाइपरटेक्स्ट मार्कअप लैंग्वेज (HTML)
  • दस्तावेज़ ऑब्जेक्ट मॉडल (DOM)
  • कैस्केडिंग स्टाइल शीट्स (सीएसएस)
  • स्केलेबल वेक्टर ग्राफिक्स (SVG)
  • JavaScript

आइए हम इन वेब मानकों में से प्रत्येक को एक-एक करके विस्तार से देखते हैं।

हाइपरटेक्स्ट मार्कअप लैंग्वेज (HTML)

जैसा कि हम जानते हैं, HTML का उपयोग वेबपेज की सामग्री को तैयार करने के लिए किया जाता है। इसे ".html" एक्सटेंशन वाली टेक्स्ट फ़ाइल में संग्रहीत किया जाता है।

Example - एक विशिष्ट नंगे-हड्डियों का HTML उदाहरण इस तरह दिखता है

<!DOCTYPE html>
<html lang = "en">
   <head>
      <meta charset = "UTF-8">
      <title></title>
   </head>

   <body>
   </body>
</html>

दस्तावेज़ ऑब्जेक्ट मॉडल (DOM)

जब एक HTML पेज एक ब्राउज़र द्वारा लोड किया जाता है, तो यह एक पदानुक्रमित संरचना में बदल जाता है। HTML में प्रत्येक टैग DOM में एक तत्व / वस्तु में एक अभिभावक-बच्चे पदानुक्रम के साथ परिवर्तित हो जाता है। यह हमारे HTML को तार्किक रूप से संरचित बनाता है। एक बार DOM बन जाने के बाद, पेज पर मौजूद तत्वों को जोड़ना (जोड़ना / संशोधित / हटाना) करना आसान हो जाता है।

आइए निम्नलिखित HTML दस्तावेज़ का उपयोग करके डोम को समझें -

<!DOCTYPE html>
<html lang = "en">
   <head>
      <title>My Document</title>
   </head>

   <body>
      <div>
         <h1>Greeting</h1>
         <p>Hello World!</p>
      </div>
   </body>
</html>

उपरोक्त HTML दस्तावेज़ का दस्तावेज़ ऑब्जेक्ट मॉडल निम्नानुसार है,

कैस्केडिंग स्टाइल शीट्स (सीएसएस)

जबकि HTML वेबपेज को एक संरचना देता है, सीएसएस शैलियों वेबपेज को देखने के लिए और अधिक सुखद बनाती है। CSS एक हैStyle Sheet LanguageHTML या XML में लिखे गए दस्तावेज़ की प्रस्तुति का वर्णन करने के लिए उपयोग किया जाता है (एसवीजी या एक्सएचटीएमएल जैसी एक्सएमएल बोलियों सहित)। CSS बताता है कि वेबपेज पर तत्वों को कैसे प्रस्तुत किया जाना चाहिए।

स्केलेबल वेक्टर ग्राफिक्स (SVG)

एसवीजी वेबपेज पर छवियों को प्रस्तुत करने का एक तरीका है। एसवीजी एक प्रत्यक्ष छवि नहीं है, लेकिन पाठ का उपयोग करके छवियां बनाने का एक तरीका है। जैसा कि इसके नाम से पता चलता है, यह एक हैScalable Vector। यह ब्राउज़र के आकार के अनुसार खुद को मापता है, इसलिए आपके ब्राउज़र का आकार बदलने से छवि विकृत नहीं होगी। IE और 8 को छोड़कर सभी ब्राउज़र SVG को सपोर्ट करते हैं। डेटा विज़ुअलाइज़ेशन दृश्य प्रतिनिधित्व हैं और यह D3G का उपयोग करके विज़ुअलाइज़ेशन को प्रस्तुत करने के लिए SVG का उपयोग करने के लिए सुविधाजनक है।

एसवीजी को एक कैनवास के रूप में सोचें, जिस पर हम विभिन्न आकृतियों को चित्रित कर सकते हैं। तो शुरू करने के लिए, आइए हम SVG टैग बनाते हैं -

<svg width = "500" height = "500"></<svg>

एसवीजी के लिए डिफ़ॉल्ट माप पिक्सेल है, इसलिए हमें यह निर्दिष्ट करने की आवश्यकता नहीं है कि हमारी इकाई पिक्सेल है या नहीं। अब, यदि हम एक आयत बनाना चाहते हैं, तो हम इसे नीचे दिए गए कोड का उपयोग करके खींच सकते हैं -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200"></rect>
</svg>

हम SVG में अन्य आकृतियाँ बना सकते हैं जैसे - रेखा, वृत्त, दीर्घवृत्त, पाठ और पथ।

HTML तत्वों को स्टाइल करने की तरह, SVG तत्वों को स्टाइल करना सरल है। आइए हम आयत की पृष्ठभूमि का रंग पीला करें। उसके लिए, हमें एक विशेषता "भरने" को जोड़ने और नीचे दिखाए गए अनुसार पीले रंग के रूप में मान निर्दिष्ट करने की आवश्यकता है -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200" fill = "yellow"></rect>
</svg>

जावास्क्रिप्ट

जावास्क्रिप्ट एक ढीला टाइप क्लाइंट साइड स्क्रिप्टिंग भाषा है जो उपयोगकर्ता के ब्राउज़र में निष्पादित होती है। वेब उपयोगकर्ता इंटरफ़ेस को इंटरैक्टिव बनाने के लिए जावास्क्रिप्ट HTML तत्वों (DOM तत्वों) के साथ सहभागिता करता है। जावास्क्रिप्ट लागू करता हैECMAScript Standards, जिसमें ECMA-262 विनिर्देशों के साथ-साथ अन्य विशेषताओं के आधार पर मुख्य विशेषताएं शामिल हैं, जो ECMAScript मानकों पर आधारित नहीं हैं। जावास्क्रिप्ट ज्ञान D3.js. के लिए एक शर्त है

चयन 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>

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

अटर () विधि

एटर () विधि का उपयोग चयनित तत्वों की विशेषता को जोड़ने या अपडेट करने के लिए किया जाता है। एक वेबपेज "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 और दोनों टैग में पाठ का रंग लाल में बदल जाता है।

डेटा जुड़ना 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>

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

डी 3 में मॉड्यूल का संग्रह होता है। आप प्रत्येक मॉड्यूल को स्वतंत्र रूप से या संचालन करने के लिए एक साथ मॉड्यूल के संग्रह का उपयोग कर सकते हैं। यह अध्याय एरे एपीआई के बारे में विस्तार से बताता है।

एक ऐरे क्या है?

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

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

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

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

एरे स्टेटिस्टिक्स एपीआई तरीके

निम्नलिखित कुछ सबसे महत्वपूर्ण सरणी आँकड़े API विधियाँ हैं।

  • d3.min(array)
  • d3.max(array)
  • d3.extent(array)
  • d3.sum(array)
  • d3.mean(array)
  • d3.quantile(array)
  • d3.variance(array)
  • d3.deviation(array)

आइए हम इनमें से प्रत्येक पर विस्तार से चर्चा करें।

d3.min (सरणी)

यह प्राकृतिक क्रम का उपयोग करके दिए गए सरणी में न्यूनतम मूल्य देता है।

Example - निम्नलिखित लिपि पर विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.min(data));
</script>

Result - उपरोक्त स्क्रिप्ट आपके कंसोल में सरणी 20 में न्यूनतम मान लौटाता है।

d3.max (सरणी)

यह किसी दिए गए एरे में अधिकतम मूल्य देता है।

Example - निम्नलिखित लिपि पर विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.max(data));
</script>

Result - उपरोक्त स्क्रिप्ट आपके कंसोल में सरणी (100) में अधिकतम मान लौटाता है।

d3.extent (सरणी)

यह दिए गए एरे में न्यूनतम और अधिकतम मूल्य देता है।

Example - निम्नलिखित लिपि पर विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.extent(data));
</script>

Result - उपर्युक्त स्क्रिप्ट एक सीमा मूल्य [20,100] लौटाती है।

d3.sum (सरणी)

यह दी गई संख्याओं की संख्या का योग देता है। यदि सरणी खाली है, तो यह 0 देता है।

Example - नीचे दिए गए विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.sum(data));
</script>

Result - उपरोक्त लिपि का मान 300 है।

d3.mean (सरणी)

यह दी गई संख्याओं के माध्य को लौटाता है।

Example - नीचे दिए गए विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.mean(data));
</script>

Result - उपरोक्त स्क्रिप्ट 60 के रूप में माध्य मान लौटाता है। इसी तरह, आप माध्य मूल्य की जांच कर सकते हैं।

d3.quantile (सरणी)

यह संख्याओं के दिए गए क्रमबद्ध सरणी के p-quantile को लौटाता है, जहाँ p [0, 1] श्रेणी में एक संख्या है। उदाहरण के लिए, माध्यिका p = 0.5 का उपयोग करके गणना की जा सकती है, पहला चतुर्थक p = 0.25 पर और तीसरा चतुर्थक p = 0.75 पर। यह कार्यान्वयन R-7 विधि, डिफ़ॉल्ट R प्रोग्रामिंग भाषा और Excel का उपयोग करता है।

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

var data = [20, 40, 60, 80, 100];
d3.quantile(data, 0); // output is 20
d3.quantile(data, 0.5); // output is 60
d3.quantile(data, 1); // output is 100

इसी तरह, आप अन्य मूल्यों की जांच कर सकते हैं।

d3.variance (सरणी)

यह दी गई संख्याओं की भिन्नता को बदलता है।

Example - निम्नलिखित लिपि पर विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.variance(data));
</script>

Result - उपरोक्त स्क्रिप्ट 1000 के रूप में विचरण मान लौटाती है।

d3.deviation (सरणी)

यह दिए गए ऐरे का मानक विचलन लौटाता है। यदि सरणी में दो से कम मान हैं, तो यह अपरिभाषित के रूप में लौटता है।

Example - नीचे दिए गए विचार करें।

<script>
   var data = [20,40,60,80,100];
   console.log(d3.deviation(data));
</script>

Result - उपरोक्त स्क्रिप्ट 31.622776601683793 के रूप में विचलन मान लौटाता है।

Example- निम्नलिखित स्क्रिप्ट का उपयोग करके ऊपर चर्चा की गई सभी ऐरे एपीआई विधियों का प्रदर्शन करते हैं। एक वेबपेज "array.html" बनाएं और उसमें निम्न परिवर्तन जोड़ें।

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

   <body>
      <h3>D3 array API</h3>
      <script>
         var data = [20,40,60,80,100];
         console.log(d3.min(data));  
         console.log(d3.max(data));
         console.log(d3.extent(data));
         console.log(d3.sum(data));
         console.log(d3.mean(data));
         console.log(d3.quantile(data,0.5));
         console.log(d3.variance(data));
         console.log(d3.deviation(data));
      </script>
   </body>
</html>

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

ऐरे खोज एपीआई तरीके

निम्नलिखित कुछ महत्वपूर्ण ऐरे खोज एपीआई तरीके हैं।

  • d3.scan(array)
  • d3.ascending (ए, बी)

आइये इन दोनों को विस्तार से समझते हैं।

d3.scan (सरणी)

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

Example -

var array = [{one: 1}, {one: 10}];
console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // output is 0
console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // output is 1

d3.ascending (ए, बी)

इस विधि का उपयोग तुलनित्र कार्य करने के लिए किया जाता है। इसे इस प्रकार लागू किया जा सकता है -

function ascending(a, b) {
   return a < b ? -1 : a > b ? 1 : a > =  b ? 0 : NaN;
}

यदि कोई तुलनित्र फ़ंक्शन अंतर्निहित सॉर्ट विधि के लिए निर्दिष्ट नहीं है, तो डिफ़ॉल्ट आदेश वर्णानुक्रमिक है। उपरोक्त फ़ंक्शन -1 देता है, यदि a, b से कम है या 1, यदि a, b से अधिक है, या 0 है।

इसी तरह, आप अवरोही (ए, बी) विधि कर सकते हैं। यह -1 लौटाता है, यदि a, b से अधिक है या 1, यदि a, b से कम है, या 0. यह फ़ंक्शन रिवर्स प्राकृतिक क्रम करता है।

Example -

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

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

   <body>
      <h3>D3 array API</h3>
      <script>
         var array = [{one: 1}, {one: 10}];
         console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // 0
         console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // 1
      </script>
   </body>
</html>

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

एरे ट्रांसफॉर्मेशन एपीआई

निम्नलिखित कुछ सबसे प्रमुख सरणी रूपांतरण एपीआई तरीके हैं।

  • d3.cross (a, b [, reducer])
  • d3.merge(arrays)
  • d3. जोड़े (सरणी [, reducer])
  • d3.permute (सरणी, अनुक्रमणिका)
  • d3.zip(arrays)

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

d3.cross (a, b [, reducer])

इस पद्धति का उपयोग दिए गए दो सरणियों ए और बी के कार्टेशियन उत्पाद को वापस करने के लिए किया जाता है। एक सरल उदाहरण नीचे परिभाषित किया गया है।

d3.cross([10, 20], ["a", "b"]); // output is [[10, "a"], [10, "b"], [20, "a"], [20, "b"]]

d3.merge (सरणियों)

इस पद्धति का उपयोग सरणियों को मर्ज करने के लिए किया जाता है और इसे नीचे परिभाषित किया गया है।

d3.merge([[10], [20]]); // output is [10, 20]

d3. जोड़े (सरणी [, reducer])

इस पद्धति का उपयोग सरणी तत्वों को जोड़ने के लिए किया जाता है और नीचे परिभाषित किया गया है।

d3.pairs([10, 20, 30, 40]); // output is [[10, 20], [20, 30], [30, 40]]

d3.permute (सरणी, अनुक्रमणिका)

इस विधि का उपयोग निर्दिष्ट सरणी और अनुक्रमित से क्रमांकन करने के लिए किया जाता है। आप किसी ऑब्जेक्ट से किसी सरणी में मान भी कर सकते हैं। इसे नीचे समझाया गया है।

var object = {fruit:"mango", color: "yellow"},
   fields = ["fruit", "color"];
d3.permute(object, fields); // output is "mango" "yellow"

d3.zip (सरणियों)

इस पद्धति का उपयोग सारणियों के एक सरणी को लौटाने के लिए किया जाता है। यदि सरणियों में केवल एक सरणी होती है, तो दिए गए सरणी में एक-तत्व सरणियाँ होती हैं। यदि कोई तर्क निर्दिष्ट नहीं है, तो लौटाया गया सरणी खाली है। इसे नीचे परिभाषित किया गया है।

d3.zip([10, 20], [30, 40]); // output is [[10, 30], [20, 40]]

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

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

   <body>
      <h3>D3 array API</h3>
      <script>
         console.log(d3.cross([10, 20], ["a", "b"]));
         console.log(d3.merge([[10], [30]]));
         console.log(d3.pairs([10, 20, 30, 40]));
         var object = {fruit:"mango", color: "yellow"},
         fields = ["fruit", "color"];
         console.log(d3.permute(object, fields)); 
         console.log(d3.zip([10, 20], [30, 40]));
      </script>
   </body>
</html>

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

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

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]

चयन दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) के शक्तिशाली डेटा-चालित परिवर्तन हैं। इसका उपयोग विशेषताएँ, शैलियाँ, गुण, HTML या पाठ सामग्री सेट करने के लिए किया जाता है और बहुत कुछ। यह अध्याय चयन एपीआई को विस्तार से बताता है।

एपीआई को कॉन्फ़िगर करना

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

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

</script>

चयन एपीआई तरीके

चयन एपीआई में सबसे महत्वपूर्ण तरीके निम्नलिखित हैं।

  • d3.selection()
  • d3.select(selector)
  • d3.selectAll(selector)
  • selection.selectAll(selector)
  • selection.filter(filter)
  • selection.merge(other)
  • d3.matcher(selector)
  • d3.creator(name)
  • selection.each(function)
  • चयन। लंबा (फ़ंक्शन [, तर्क ...])
  • d3.local()
  • स्थानीय .सेट (नोड, मान)
  • local.get(node)
  • local.remove(node)

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

d3.selection ()

इस विधि का उपयोग मूल तत्व का चयन करने के लिए किया जाता है। इस फ़ंक्शन का उपयोग चयन के लिए परीक्षण करने या चयन d3js का विस्तार करने के लिए भी किया जा सकता है।

d3.select (चयनकर्ता)

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

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

var body = d3.select("body");

यदि चयनकर्ता एक स्ट्रिंग नहीं है, तो यह निर्दिष्ट नोड का चयन करता है, जिसे नीचे परिभाषित किया गया है।

d3.select("p").style("color", "red");

d3.selectAll (चयनकर्ता)

यह विधि उन सभी तत्वों का चयन करती है जो निर्दिष्ट चयनकर्ता स्ट्रिंग से मेल खाते हैं।

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

var body = d3.selectAll("body");

यदि चयनकर्ता एक स्ट्रिंग नहीं है, तो यह नोड्स के निर्दिष्ट सरणी का चयन करता है, जिसे नीचे परिभाषित किया गया है।

d3.selectAll("body").style("color", "red");

selection.selectAll (चयनकर्ता)

इस विधि का उपयोग किसी तत्व का चयन करने के लिए किया जाता है। यह उन निर्दिष्ट तत्वों का चयन करता है जो निर्दिष्ट चयनकर्ता स्ट्रिंग से मेल खाते हैं। लौटे चयन में तत्वों को इस चयन में उनके संबंधित मूल नोड द्वारा वर्गीकृत किया गया है। यदि कोई तत्व वर्तमान तत्व के लिए निर्दिष्ट चयनकर्ता से मेल नहीं खाता है, या यदि चयनकर्ता शून्य है, तो वर्तमान सूचकांक में समूह खाली हो जाएगा।

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

var b = d3.selectAll("p").selectAll("b");

selection.filter (फिल्टर)

इस पद्धति का उपयोग चयन को फ़िल्टर करने के लिए किया जाता है, एक नया चयन लौटाता है जिसमें केवल वे तत्व होते हैं जिनके लिए निर्दिष्ट फ़िल्टर सत्य है।

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

var even = d3.selectAll("tr").filter(":nth-child(odd)");

यहां, तालिका पंक्तियों के चयन को केवल विषम फ़िल्टर करें।

selection.merge (अन्य)

इस पद्धति का उपयोग निर्दिष्ट अन्य चयन के साथ एक नए चयन विलय को वापस करने के लिए किया जाता है।

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

var rect = svg.selectAll("rect").data(data);
rect.enter().append("rect").merge(rect);

d3.matcher (चयनकर्ता)

इस पद्धति का उपयोग निर्दिष्ट चयनकर्ता को निर्दिष्ट करने के लिए किया जाता है। यह एक फंक्शन लौटाता है, जो सच होता है।

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

var p = selection.filter(d3.matcher("p"));

d3.creator (नाम)

इस पद्धति का उपयोग निर्दिष्ट तत्व नाम को निर्दिष्ट करने के लिए किया जाता है। यह एक फ़ंक्शन देता है, जो दिए गए नाम का एक तत्व बनाता है, यह मानते हुए कि यह मूल तत्व है।

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

selection.append(d3.creator("p"));

selection.each (समारोह)

इस विधि का उपयोग प्रत्येक चयनित तत्व के लिए निर्दिष्ट कार्य को वर्तमान डेटम (d), वर्तमान सूचकांक (i) और वर्तमान समूह (नोड्स) द्वारा वर्तमान DOM तत्व (नोड्स [i) के रूप में पारित करने के लिए किया जाता है। ])। इसे नीचे समझाया गया है।

parent.each(function(p, j) {
   d3.select(this)
      .selectAll(".child")
      .text(function(d, i) { return "child " + d.name + " of " + p.name; });
});

चयन। लंबा (फ़ंक्शन [, तर्क ...])

इसका उपयोग निर्दिष्ट फ़ंक्शन को एक बार ठीक करने के लिए किया जाता है। वाक्य रचना नीचे दिखाया गया है।

function name(selection, first, last) {
   selection.attr("first-name", first).attr("last-name", last);
}

इस विधि को नीचे दिखाए अनुसार निर्दिष्ट किया जा सकता है।

d3.selectAll("p").call(name, "Adam", "David");

d3.local ()

डी 3 स्थानीय आपको स्थानीय राज्य को परिभाषित करने की अनुमति देता है जो डेटा से स्वतंत्र है।

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

var data = d3.local();

वर् के विपरीत, प्रत्येक स्थानीय का मान भी DOM द्वारा स्कोप किया जाता है।

स्थानीय .सेट (नोड, मान)

यह विधि निर्दिष्ट नोड पर इस स्थानीय के मान को मान पर सेट करती है।

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

selection.each(function(d) 
   { data.set(this, d.value); });
local.get(node)

यह विधि निर्दिष्ट नोड पर इस स्थानीय का मान लौटाती है। यदि नोड इस स्थानीय को परिभाषित नहीं करता है, तो यह निकटतम पूर्वज से मान लौटाता है जो इसे परिभाषित करता है।

local.remove (नोड)

यह विधि निर्दिष्ट नोड से इस स्थानीय मान को हटा देती है। यदि नोड परिभाषित किया गया है, तो यह सही है, अन्यथा गलत है।

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

पथ कॉन्फ़िगर करना

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

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

</script>

पथ एपीआई तरीके

कुछ सबसे अधिक उपयोग किए जाने वाले पथ एपीआई तरीकों को संक्षेप में निम्नानुसार वर्णित किया गया है।

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

  • path.moveTo(x, y) - इस पद्धति का उपयोग निर्दिष्ट x और y मानों को स्थानांतरित करने के लिए किया जाता है।

  • path.closePath() - इस विधि का उपयोग वर्तमान पथ को बंद करने के लिए किया जाता है।

  • path.lineTo(x, y) - इस पद्धति का उपयोग वर्तमान बिंदु से परिभाषित x, y मानों तक की रेखा बनाने के लिए किया जाता है।

  • path.quadraticCurveTo(cpx, cpy, x, y) - इस पद्धति का उपयोग वर्तमान बिंदु से निर्दिष्ट बिंदु तक एक द्विघात वक्र खींचने के लिए किया जाता है।

  • path.bezierCurveTo(cpx1, cpy1, cpx2, cpy2, x, y) - इस विधि का प्रयोग वर्तमान बिंदु से निर्दिष्ट बिंदु तक बीज़ियर वक्र को खींचने के लिए किया जाता है।

  • path.arcTo(x1, y1, x2, y2, radius) - इस पद्धति का उपयोग वर्तमान बिंदु से एक निर्दिष्ट बिंदु (X1, y1) तक एक गोलाकार चाप खींचने और निर्दिष्ट बिंदुओं (X1, y1) और (x2, y2) के बीच की रेखा को समाप्त करने के लिए किया जाता है।

  • path.arc(x, y, radius, startAngle, endAngle[, anticlockwise])- इस पद्धति का उपयोग निर्दिष्ट केंद्र (x, y), त्रिज्या, प्रारंभ और अंत में कोण के लिए एक गोलाकार चाप खींचने के लिए किया जाता है। यदि एंटीक्लॉकवाइज वैल्यू सत्य है तो आर्क को एंटिक्लॉकवाइज दिशा में खींचा जाता है, अन्यथा इसे क्लॉकवाइज दिशा में खींचा जाता है।

  • path.rect(x, y, w, h)- इस विधि का उपयोग केवल चार बिंदुओं (x, y), (x + w, y), (x + w, y + h), (x, y + h) वाले नए उप पथ बनाने के लिए किया जाता है। इन चार बिंदुओं के साथ सीधी रेखाएं जुड़ी होती हैं जो उपपथ को बंद के रूप में चिह्नित करती हैं। संदर्भ के समतुल्य। सही है और एसवीजी के "लिनेटो" कमांड का उपयोग करता है।

  • path.toString() - एसवीजी के पथ डेटा विनिर्देश के अनुसार इस पथ का स्ट्रिंग प्रतिनिधित्व लौटाता है।

उदाहरण

पथ एपीआई का उपयोग करके डी 3 में एक सरल रेखा खींचते हैं। एक वेबपेज बनाएंlinepath.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<!DOCTYPE html>
<meta charset = "UTF-8">
   <head>
      <title>SVG path line Generator</title>
   </head>

   <style>
      path {
         fill: green;
         stroke: #aaa;
      }
   </style>
   
   <body>
      <svg width = "600" height = "100">
         <path transform = "translate(200, 0)" />
      </svg>
      
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <script>
         var data = [[0, 20], [50, 30], [100, 50], [200, 60], [300, 90]];
         var lineGenerator = d3.line();
         var pathString = lineGenerator(data);
         d3.select('path').attr('d', pathString);
      </script>
   </body>
</html>

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

D3.js डेटा परिवर्तन करने के लिए स्केल फ़ंक्शंस प्रदान करता है। ये फ़ंक्शन इनपुट डोमेन को आउटपुट रेंज में मैप करते हैं।

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

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

<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-format.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-time.v1.min.js"></script>
<script src = "https://d3js.org/d3-time-format.v2.min.js"></script>
<script src = "https://d3js.org/d3-scale.v1.min.js"></script>
<script>

</script>

तराजू एपीआई तरीके

डी 3 विभिन्न प्रकार के चार्ट के लिए निम्न महत्वपूर्ण स्केलिंग विधियाँ प्रदान करता है। आइए फिर विस्तार से समझते हैं।

  • d3.scaleLinear() - एक सतत रेखीय पैमाने का निर्माण करता है जहां हम निर्दिष्ट आउटपुट रेंज में डेटा (डोमेन) मैप्स इनपुट कर सकते हैं।

  • d3.scaleIdentity() - एक रैखिक पैमाने का निर्माण करें जहां इनपुट डेटा आउटपुट के समान है।

  • d3.scaleTime() - एक रेखीय पैमाने का निर्माण करें जहां इनपुट डेटा दिनांक और आउटपुट संख्याओं में है।

  • d3.scaleLog() - एक लघुगणकीय पैमाने का निर्माण।

  • d3.scaleSqrt() - एक वर्गमूल पैमाने का निर्माण।

  • d3.scalePow() - एक घातीय पैमाने का निर्माण।

  • d3.scaleSequential() - एक अनुक्रमिक पैमाने का निर्माण करें जहां आउटपुट रेंज इंटरपोलर फ़ंक्शन द्वारा तय किया गया है।

  • d3.scaleQuantize() - असतत उत्पादन सीमा के साथ एक मात्रा पैमाने का निर्माण।

  • d3.scaleQuantile() - जहां इनपुट नमूना डेटा नक्शे असतत उत्पादन सीमा के लिए एक मात्रात्मक पैमाने का निर्माण।

  • d3.scaleThreshold() - एक पैमाने का निर्माण करें जहां असतत आउटपुट रेंज के लिए मनमाना इनपुट डेटा मैप करता है।

  • d3.scaleBand() - बैंड स्केल ऑर्डिनल स्केल की तरह होते हैं सिवाय आउटपुट रेंज के निरंतर और न्यूमेरिक।

  • d3.scalePoint() - एक बिंदु पैमाने का निर्माण।

  • d3.scaleOrdinal() - एक क्रमिक पैमाने का निर्माण करें जहां इनपुट डेटा में अक्षर शामिल होते हैं और असतत संख्यात्मक आउटपुट रेंज में मैप किए जाते हैं।

कार्य का उदाहरण देने से पहले, आइए पहले निम्नलिखित दो शब्दों को समझें -

  • Domain - डोमेन आपके इनपुट डेटा के न्यूनतम और अधिकतम मूल्यों को दर्शाता है।

  • Range - रेंज आउटपुट रेंज है, जिसे हम मैप करने के लिए इनपुट मानों को पसंद करेंगे ...

काम करने का उदाहरण

इस उदाहरण में d3.scaleLinear फ़ंक्शन करते हैं। ऐसा करने के लिए, आपको निम्नलिखित चरणों का पालन करना होगा -

Step 1 - Define variables - एसवीजी वेरिएबल्स और डेटा को नीचे कोडिंग का उपयोग करके परिभाषित करें।

var data = [100, 200, 300, 400, 800, 0]
   var width = 500, 
      barHeight = 20, 
      margin = 1;

Step 2 - Create linear scale - रैखिक स्केल बनाने के लिए निम्न कोड का उपयोग करें।

var scale = d3.scaleLinear()
   .domain([d3.min(data), d3.max(data)])
   .range([100, 400]);

यहाँ, अपने डोमेन के लिए न्यूनतम और अधिकतम मान के लिए, हम बिल्ट-इन का उपयोग कर सकते हैं d3.min() तथा d3.max() फ़ंक्शंस, जो हमारे डेटा सरणी से क्रमशः न्यूनतम और अधिकतम मान लौटाएंगे।

Step 3 - Append SVG attributes - नीचे दिए गए कोड का उपयोग करके एसवीजी तत्वों को जोड़ें।

var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", barHeight * data.length);

Step 4 - Apply transformation - नीचे दिए गए कोड का उपयोग करके परिवर्तन लागू करें।

var g = svg.selectAll("g")
   .data(data).enter().append("g")
   .attr("transform", function (d, i) {
      return "translate(0," + i * barHeight + ")";
});

Step 5 - Append rect elements - नीचे दिखाए गए अनुसार स्केलिंग तत्वों को जोड़ें।

g.append("rect")
   .attr("width", function (d) {
      return scale(d);
   })
   .attr("height", barHeight - margin)

Step 6 - Display data - अब नीचे दिए गए कोडिंग का उपयोग करके डेटा प्रदर्शित करें।

g.append("text")
   .attr("x", function (d) { return (scale(d)); })
   .attr("y", barHeight / 2)
   .attr("dy", ".35em")
   .text(function (d) { return d; });

Step 7 - Working Example - अब, हम d3.scaleLinear () फ़ंक्शन का उपयोग करके एक बार चार्ट बनाते हैं।

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

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

   <body>
      <script>
         var data = [100, 200, 300, 350, 400, 250]
         var width = 500, barHeight = 20, margin = 1;
         
         var scale = d3.scaleLinear()
            .domain([d3.min(data), d3.max(data)])
            .range([100, 400]);
         
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", barHeight * data.length);
         
         var g = svg.selectAll("g")
            .data(data)
            .enter()
            .append("g")
            .attr("transform", function (d, i) {
               return "translate(0," + i * barHeight + ")";
         });
    
         g.append("rect")
         .attr("width", function (d) {
            return scale(d);
         })
         
         .attr("height", barHeight - margin)
         g.append("text")
         .attr("x", function (d) { return (scale(d)); })
         .attr("y", barHeight / 2).attr("dy", ".35em")
         .text(function (d) { return d; });
      </script>
   </body>
</html>

उपरोक्त कोड ब्राउज़र में निम्नलिखित परिणाम प्रदर्शित करेगा।

डी 3 कुल्हाड़ियों को खींचने के लिए कार्य प्रदान करता है। एक अक्ष रेखा, टिक्स और लेबल से बना होता है। एक अक्ष स्केल का उपयोग करता है, इसलिए प्रत्येक अक्ष को कार्य करने के लिए एक स्केल दिया जाना चाहिए।

एक्सिस एपीआई को कॉन्फ़िगर करना

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

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

</script>

एक्सिस एपीआई तरीके

डी 3 कुल्हाड़ियों को खींचने के लिए निम्नलिखित महत्वपूर्ण कार्य प्रदान करता है। वे संक्षिप्त रूप में वर्णित हैं।

  • d3.axisTop() - इस पद्धति का उपयोग शीर्ष क्षैतिज अक्ष बनाने के लिए किया जाता है।

  • d3.axisRight() - इस पद्धति का उपयोग एक ऊर्ध्वाधर दाएं-उन्मुख धुरी बनाने के लिए किया जाता है।

  • d3.axisBottom() - इस पद्धति का उपयोग नीचे क्षैतिज अक्ष बनाने के लिए किया जाता है।

  • d3.axisLeft() - यह बाएं ऊर्ध्वाधर अक्ष बनाता है।

काम करने का उदाहरण

आइए जानें कि x और y- अक्ष को ग्राफ में कैसे जोड़ा जाए। ऐसा करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा।

Step 1 - Define variables - एसवीजी और डेटा चर को नीचे दिए गए कोड का उपयोग करके परिभाषित करें।

var width = 400, height = 400;
var data = [100, 150, 200, 250, 280, 300];
var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", height);

Step 2 - Create a scale linear function - नीचे परिभाषित के रूप में x और y अक्ष दोनों के लिए एक स्केल रैखिक फ़ंक्शन बनाएं।

var xscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([0, width - 100]);

var yscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([height/2, 0]);

यहां, हमने एक रेखीय पैमाना बनाया है और डोमेन और रेंज को निर्दिष्ट किया है।

Step 3 - Add scales to x-axis - अब, हम निम्नलिखित कोड का उपयोग करके एक्स-एक्सिस में स्केल जोड़ सकते हैं।

var x_axis = d3.axisBottom()
   .scale(xscale);

यहां, हम अपने एक्स-एक्सिस को बनाने और स्केल के साथ प्रदान करने के लिए d3.axisBottom का उपयोग करते हैं, जो पहले परिभाषित किया गया है।

Step 4 - Add scales to the y-axis - y- अक्ष में स्केल जोड़ने के लिए निम्न कोड का उपयोग करें।

var y_axis = d3.axisLeft()
   .scale(yscale);

यहां, हम अपने y- अक्ष बनाने के लिए d3.axisLeft का उपयोग करते हैं और इसे उस पैमाने के साथ प्रदान करते हैं जिसे हमने ऊपर परिभाषित किया है।

Step 5 - Apply transformation - आप एक समूह तत्व जोड़ सकते हैं और एक्स, वाई अक्ष डाल सकते हैं, जो नीचे परिभाषित किया गया है।

svg.append("g")
   .attr("transform", "translate(50, 10)")
   .call(y_axis);

Step 6 - Append group elements - निम्नलिखित कोड का उपयोग करके संक्रमण और समूह तत्वों को लागू करें।

var xAxisTranslate = height/2 + 10;
svg.append("g")
   .attr("transform", "translate(50, " + xAxisTranslate  +")")
   .call(x_axis)

Step 7 - Working Example- पूर्ण कोड लिस्टिंग निम्नलिखित कोड ब्लॉक में दी गई है। एक वेबपेज बनाएंaxes.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         svg text {
            fill: purple;
            font: 12px sans-serif;
            text-anchor: end;
         }
      </style>
   </head>

   <body>
      <script>
         var width = 400, height = 400;
         var data = [100, 120, 140, 160, 180, 200];
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         
         var xscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([0, width - 100]);
         
         var yscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([height/2, 0]);
    
         var x_axis = d3.axisBottom().scale(xscale);
         
         var y_axis = d3.axisLeft().scale(yscale);
         
         svg.append("g")
            .attr("transform", "translate(50, 10)")
            .call(y_axis);
         
         var xAxisTranslate = height/2 + 10;
         
         svg.append("g")
            .attr("transform", "translate(50, " + xAxisTranslate  +")")
            .call(x_axis)
      </script>
   </body>
</html>

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

यह अध्याय D3.js. में अलग-अलग आकार के जनरेटर की चर्चा करता है।

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

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

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

</script>

आकार जनरेटर

D3.js विभिन्न आकृतियों का समर्थन करता है। आइए विस्तार से प्रमुख आकृतियों के बारे में जानें।

आर्क एपीआई

आर्क जनरेटर एक सर्कल या एनलस आकार का उत्पादन करता है। हमने पिछले पाई चार्ट अध्याय में इन एपीआई विधियों का उपयोग किया है। आइए विभिन्न आर्क एपीआई तरीकों को विस्तार से समझते हैं।

  • d3.arc() - इस विधि का उपयोग एक नया आर्क जनरेटर बनाने के लिए किया जाता है।

  • arc(args)- इसका उपयोग निर्दिष्ट दिए गए तर्कों के साथ एक आर्क उत्पन्न करने के लिए किया जाता है। ऑब्जेक्ट रेडी और कोणों के साथ डिफ़ॉल्ट सेटिंग्स नीचे परिभाषित की गई हैं।

<script>
   var arc = d3.arc();
   arc({
      innerRadius: 0,
      outerRadius: 100,
      startAngle: 0,
      endAngle: Math.PI / 2
   });
</script>
  • arc.centroid(args) - इस पद्धति का उपयोग निर्दिष्ट तर्कों के साथ चाप के मध्य रेखा के midpoint [x, y] की गणना करने के लिए किया जाता है।

  • arc.innerRadius([radius])- इस पद्धति का उपयोग दिए गए त्रिज्या से आंतरिक त्रिज्या को सेट करने और एक आर्क जनरेटर को वापस करने के लिए किया जाता है। यह नीचे परिभाषित किया गया है -

function innerRadius(d) {
   return d.innerRadius;
}
  • arc.outerRadius([radius])- इस पद्धति का उपयोग दिए गए त्रिज्या से बाहरी त्रिज्या को सेट करने और आर्क जनरेटर को वापस करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है।

function outerRadius(d) {
   return d.outerRadius;
}
  • arc.cornerRadius([radius])- इस विधि का उपयोग दिए गए त्रिज्या से कोने के त्रिज्या को सेट करने और आर्क जनरेटर को वापस करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है।

function cornerRadius() {
   return 0;
}

यदि कोने त्रिज्या शून्य से अधिक है, तो दिए गए त्रिज्या के हलकों का उपयोग करके चाप के कोनों को गोल किया जाता है। कोने का दायरा (आउटररेडियस - इनररेडियस) / 2 से बड़ा नहीं हो सकता है।

  • arc.startAngle([angle])- इस पद्धति का उपयोग दिए गए कोण से फ़ंक्शन को प्रारंभ कोण सेट करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है -

function startAngle(d) {
   return d.startAngle;
}
  • arc.endAngle([angle])- इस पद्धति का उपयोग दिए गए कोण से फ़ंक्शन के अंत कोण को सेट करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है।

function endAngle(d) {
   return d.endAngle;
}
  • arc.padAngle([angle])- इस विधि का उपयोग दिए गए एंगल से पैड एंगल को फंक्शन में सेट करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है।

function padAngle() {
   return d && d.padAngle;
}
  • (x) arc.padRadius([radius])- इस पद्धति का उपयोग दिए गए त्रिज्या से निर्दिष्ट कार्य के लिए पैड त्रिज्या को सेट करने के लिए किया जाता है। पैड त्रिज्या आसन्न चाप को अलग करने वाली निश्चित रैखिक दूरी को निर्धारित करता है, जिसे पैडारियस * पैडअंगल के रूप में परिभाषित किया गया है।

  • (xi) arc.context([context]) - इस पद्धति का उपयोग संदर्भ सेट करने और आर्क जनरेटर को वापस करने के लिए किया जाता है।

पीआईएस एपीआई

इस API का उपयोग पाई जनरेटर बनाने के लिए किया जाता है। हमने पिछले अध्याय में इन एपीआई तरीकों का प्रदर्शन किया है। हम उन सभी तरीकों पर विस्तार से चर्चा करेंगे।

  • d3.pie() - डिफ़ॉल्ट सेटिंग्स के साथ एक नया पाई जनरेटर का निर्माण करता है।

  • pie(data[, arguments])- इस विधि का उपयोग दिए गए सरणी मानों के लिए पाई उत्पन्न करने के लिए किया जाता है। यह वस्तुओं की एक सरणी देता है। ऑब्जेक्ट डेटम के आर्क कोण हैं। प्रत्येक वस्तु में निम्नलिखित गुण होते हैं -

    • data- इनपुट डेटम; इनपुट डेटा सरणी में संबंधित तत्व।

    • value - चाप का संख्यात्मक मान।

    • index - चाप का सूचकांक।

    • startAngle - चाप का प्रारंभ कोण।

    • endAngle - चाप का अंत कोण।

    • padAngle - चाप का पैड कोण।

  • pie.value([value])- इस विधि का उपयोग निर्दिष्ट फ़ंक्शन में मान सेट करने के लिए किया जाता है और एक पाई उत्पन्न करता है। इसे निम्नानुसार परिभाषित किया गया है -

function value(d) {
   return d;
}
  • pie.sort([compare])- इस पद्धति का उपयोग निर्दिष्ट फ़ंक्शन के डेटा को सॉर्ट करने के लिए किया जाता है और पाई उत्पन्न करता है। तुलनित्र फ़ंक्शन को निम्नानुसार परिभाषित किया गया है।

pie.sort(function(a, b) 
   { return a.name.localeCompare(b.name); }
);

यहाँ, तुलना फ़ंक्शन दो तर्कों को 'a' और 'b' लेता है, इनपुट डेटा ऐरे से प्रत्येक तत्व। यदि 'a' के लिए चाप 'b' के लिए चाप से पहले होना चाहिए, तो तुलनित्र को शून्य से कम संख्या लौटानी चाहिए। यदि 'a' के लिए चाप 'b' के लिए चाप के बाद होना चाहिए, तो तुलनित्र को शून्य से अधिक संख्या लौटानी चाहिए।

  • pie.sortValues([compare])- इस विधि का उपयोग दिए गए फ़ंक्शन से मूल्य की तुलना करने के लिए किया जाता है और एक पाई उत्पन्न करता है। फ़ंक्शन को निम्नानुसार परिभाषित किया गया है।

function compare(a, b) {
   return b - a;
}
  • pie.startAngle([angle])- इस विधि का उपयोग पाई के प्रारंभ कोण को निर्दिष्ट फ़ंक्शन पर सेट करने के लिए किया जाता है। यदि कोण निर्दिष्ट नहीं है, तो यह वर्तमान प्रारंभ कोण लौटाता है। इसे निम्नानुसार परिभाषित किया गया है।

function startAngle() {
   return 0;
}
  • pie.endAngle([angle])- इस विधि का उपयोग पाई के अंतिम कोण को निर्दिष्ट फ़ंक्शन पर सेट करने के लिए किया जाता है। यदि कोण निर्दिष्ट नहीं है, तो यह वर्तमान अंत कोण लौटाता है। इसे निम्नानुसार परिभाषित किया गया है।

function endAngle() {
   return 2 * Math.PI;
}
  • pie.padAngle([angle])- इस पद्धति का उपयोग पैड को निर्दिष्ट फ़ंक्शन पर सेट करने के लिए किया जाता है और पाई उत्पन्न करता है। फ़ंक्शन को निम्नानुसार परिभाषित किया गया है।

function padAngle() {
   return 0;
}

लाइन्स एपीआई

लाइन्स API का उपयोग लाइन बनाने के लिए किया जाता है। हमने इन API विधियों का उपयोग किया हैGraphsअध्याय। आइए हम प्रत्येक विधियों के बारे में विस्तार से जाने।

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

  • line(data) - इस विधि का उपयोग डेटा के दिए गए सरणी के लिए एक लाइन उत्पन्न करने के लिए किया जाता है।

  • line.x([x])- इस विधि का उपयोग एक्स एक्सेसर को निर्दिष्ट फ़ंक्शन पर सेट करने के लिए किया जाता है और एक लाइन उत्पन्न करता है। फ़ंक्शन को नीचे परिभाषित किया गया है,

function x(d) {
   return d[0];
}
  • line.y([y])- इस पद्धति का उपयोग निर्दिष्ट फ़ंक्शन के लिए 'y' एक्सेसर को सेट करने के लिए किया जाता है और एक लाइन उत्पन्न करता है। फ़ंक्शन को निम्नानुसार परिभाषित किया गया है।

function y(d) {
   return d[1];
}
  • line.defined([defined])- इस पद्धति का उपयोग निर्दिष्ट फ़ंक्शन को परिभाषित एक्सेसर सेट करने के लिए किया जाता है। इसे निम्नानुसार परिभाषित किया गया है।

function defined() {
  return true;
}
  • line.curve([curve]) - इसका उपयोग वक्र सेट करने के लिए किया जाता है और लाइन उत्पन्न करता है।

  • line.context([context])- इस विधि का उपयोग संदर्भ सेट करने के लिए किया जाता है और एक लाइन उत्पन्न करता है। यदि संदर्भ निर्दिष्ट नहीं है, तो यह रिक्त हो जाता है।

  • d3.lineRadial()- इस विधि का उपयोग नई रेडियल लाइन बनाने के लिए किया जाता है; यह कार्टेशियन लाइन जनरेटर के बराबर है।

  • lineRadial.radius([radius])- इस पद्धति का उपयोग रेडियल रेखा खींचने के लिए किया जाता है और अभिग्रहणकर्ता त्रिज्या लौटाता है। यह मूल (0,0) से दूरी लेता है।

अगले अध्याय में, हम D3.js. में कलर्स एपीआई के बारे में जानेंगे।

रंगों को RED, GREEN और BLUE के संयोजन से प्रदर्शित किया जाता है। रंगों को निम्नलिखित विभिन्न तरीकों से निर्दिष्ट किया जा सकता है -

  • रंग नामों से
  • RGB मूल्यों के रूप में
  • हेक्साडेसिमल मानों के रूप में
  • एचएसएल मूल्यों के रूप में
  • HWB मानों के रूप में

डी 3-रंग एपीआई विभिन्न रंगों के लिए प्रतिनिधित्व प्रदान करता है। आप एपीआई में रूपांतरण और हेरफेर संचालन कर सकते हैं। आइए इन ऑपरेशनों को विस्तार से समझते हैं।

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

आप निम्न स्क्रिप्ट का उपयोग करके सीधे API लोड कर सकते हैं।

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

</script>

मूलभूत क्रियाएं

डी 3 में मूल रंग संचालन के माध्यम से चलते हैं।

Convert color value to HSL - रंग मूल्य को एचएसएल में परिवर्तित करने के लिए, निम्नलिखित का उपयोग करें Example -

var convert = d3.hsl("green");

आप नीचे दिखाए अनुसार hue को 45 ° से घुमा सकते हैं।

convert.h + =  45;

इसी तरह, आप संतृप्ति स्तर को भी बदल सकते हैं। रंग मूल्य फीका करने के लिए, आप नीचे दिखाए गए अनुसार अस्पष्टता मान बदल सकते हैं।

convert.opacity = 0.5;

रंग एपीआई तरीके

निम्नलिखित कुछ सबसे महत्वपूर्ण कलर एपीआई तरीके हैं।

  • d3.color(specifier)
  • color.opacity
  • color.rgb()
  • color.toString()
  • color.displayable()
  • d3.rgb(color)
  • d3.hsl(color)
  • d3.lab(color)
  • d3.hcl(color)
  • d3.cubehelix(color)

आइए हम इन कलर एपीआई तरीकों में से प्रत्येक को विस्तार से समझते हैं।

d3.color (विनिर्देशक)

इसका उपयोग निर्दिष्ट सीएसएस रंग को पार्स करने और आरजीबी या एचएसएल रंग को वापस करने के लिए किया जाता है। यदि निर्दिष्ट नहीं दिया जाता है, तो नल वापस कर दिया जाता है।

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

<script>
   var color = d3.color("green");  // asign color name directly
   console.log(color);
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे -

{r: 0, g: 128, b: 0, opacity: 1}

color.opacity

यदि हम रंग को फीका करना चाहते हैं, तो हम अस्पष्टता मान को बदल सकते हैं। यह [0, 1] की सीमा में है।

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

<script>
   var color = d3.color("green");
   console.log(color.opacity);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे -

1

color.rgb ()

यह रंग के लिए RGB मान लौटाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.rgb());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

{r: 0, g: 128, b: 0, opacity: 1}

color.toString ()

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

<script>
   var color = d3.color("green");
   console.log(color.toString());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

rgb(0, 128, 0)

color.displayable ()

सही है, अगर रंग प्रदर्शन योग्य है। गलत रिटर्न देता है, यदि RGB रंग मान 0 से कम या 255 से अधिक है, या यदि अपारदर्शिता रेंज [0, 1] में नहीं है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.displayable());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

true

d3.rgb (रंग)

इस विधि का उपयोग एक नया RGB रंग बनाने के लिए किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   console.log(d3.rgb("yellow"));
   console.log(d3.rgb(200,100,0));
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{r: 255, g: 255, b: 0, opacity: 1}
{r: 200, g: 100, b: 0, opacity: 1}

d3.hsl (रंग)

इसका उपयोग एक नए एचएसएल रंग के निर्माण के लिए किया जाता है। मानों को दिए गए उदाहरण पर h, s और l गुणों के रूप में उजागर किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hsl = d3.hsl("blue");
   console.log(hsl.h + =  90);
   console.log(hsl.opacity = 0.5);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

330
0.5

d3.lab (रंग)

यह एक नए लैब रंग का निर्माण करता है। चैनल मान लौटाए गए उदाहरण पर 'l', 'a' और 'b' गुणों के रूप में सामने आते हैं।

<script>
   var lab = d3.lab("blue");
   console.log(lab);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{l: 32.29701093285073, a: 79.18751984512221, b: -107.8601617541481, opacity: 1}

d3.hcl (रंग)

एक नया HCL रंग बनाता है। चैनल मान लौटाए गए उदाहरण पर h, c और l गुणों के रूप में सामने आते हैं। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{h: 306.2849380699878, c: 133.80761485376166, l: 32.29701093285073, opacity: 1}

d3.cubehelix (रंग)

एक नया क्यूबेलिक्स रंग बनाता है। मानों को दिए गए उदाहरण पर h, s और l गुणों के रूप में उजागर किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे,

{h: 236.94217167732103, s: 4.614386868039719, l: 0.10999954957200976, opacity: 1}

काम करने का उदाहरण

आइए हम एक नया वेबपेज बनाएं - color.htmlसभी रंग एपीआई तरीकों का प्रदर्शन करने के लिए। पूर्ण कोड सूची नीचे परिभाषित की गई है।

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

   <body>
      <h3>D3 colors API</h3>
      <script>
         var color = d3.color("green");
         console.log(color);
         console.log(color.opacity);
         console.log(color.rgb());
         console.log(color.toString());
         console.log(color.displayable());
         console.log(d3.rgb("yellow"));
         console.log(d3.rgb(200,100,0));
         var hsl = d3.hsl("blue");
         console.log(hsl.h + =  90);
         console.log(hsl.opacity = 0.5);
         var lab = d3.lab("blue");
         console.log(lab);
         var hcl = d3.hcl("blue");
         console.log(hcl);
         var cube = d3.cubehelix("blue");
         console.log(cube);
      </script>
   </body>
</html>

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

डी 3 संक्रमण तत्वों का चयन और प्रत्येक तत्व के लिए; यह तत्व की वर्तमान परिभाषा के एक हिस्से पर एक संक्रमण लागू करता है।

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

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

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script>

</script>

संक्रमण एपीआई तरीके

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

तत्वों का चयन

आइए विभिन्न चयन तत्वों पर विस्तार से चर्चा करें।

  • selection.transition([name])- नाम के साथ एक नया चयन संक्रमण वापस करने के लिए इस पद्धति का उपयोग किया जाता है। यदि कोई नाम निर्दिष्ट नहीं है, तो यह अशक्त है।

  • selection.interrupt([name]) - इस पद्धति का उपयोग नाम के साथ संक्रमण के चयनित तत्वों को बाधित करने के लिए किया जाता है और नीचे परिभाषित किया गया है।

selection.interrupt().selectAll("*").interrupt();
  • d3.interrupt(node[, name]) - इस विधि का उपयोग निर्दिष्ट नोड पर निर्दिष्ट नाम के संक्रमण को बाधित करने के लिए किया जाता है।

  • d3.transition([name]) - इस पद्धति का उपयोग निर्दिष्ट नाम के साथ एक नया संक्रमण वापस करने के लिए किया जाता है।

  • transition.select(selector) - इस पद्धति का उपयोग पहले तत्व का चयन करने के लिए किया जाता है जो निर्दिष्ट चयनकर्ता से मेल खाता है और परिणामस्वरूप चयन पर एक संक्रमण लौटाता है, जिसे नीचे परिभाषित किया गया है।

transition
   .selection()
   .select(selector)
   .transition(transition)
  • transition.selectAll(selector)- इस पद्धति का उपयोग उन सभी तत्वों का चयन करने के लिए किया जाता है जो निर्दिष्ट चयनकर्ता से मेल खाते हैं और परिणामस्वरूप चयन पर एक संक्रमण लौटाते हैं। यह नीचे परिभाषित किया गया है -

transition
   .selection()
   .selectAll(selector)
   .transition(transition)
  • transition.filter(filter) - इस पद्धति का उपयोग निर्दिष्ट फ़िल्टर से मेल खाने वाले तत्वों का चयन करने के लिए किया जाता है, उन्हें नीचे परिभाषित किया गया है।

transition
   .selection()
   .filter(filter)
   .transition(transition)
  • transition.merge(other)- इस पद्धति का उपयोग अन्य संक्रमण के साथ संक्रमण को मर्ज करने के लिए किया जाता है। इसे नीचे परिभाषित किया गया है।

transition
   .selection()
   .merge(other.selection())
   .transition(transition)
  • transition.transition()- इस पद्धति का उपयोग चयनित तत्वों पर एक नया संक्रमण वापस करने के लिए किया जाता है। जब संक्रमण बंद हो जाता है, तो इसे शुरू करना निर्धारित होता है। नया संक्रमण इस संक्रमण के नाम, अवधि और सहजता को प्राप्त करता है।

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

d3.selectAll(".body")
   .transition() 
   
   // fade to yellow.
   .style("fill", "yellow")
   .transition() 
   
   // Wait for five second. Then change blue, and remove.
   .delay(5000)
   .style("fill", "blue")
   .remove();

यहां, शरीर पीला पड़ जाता है और अंतिम संक्रमण से सिर्फ पांच सेकंड पहले शुरू होता है।

  • d3.active(node[, name]) - इस विधि का उपयोग नाम के साथ निर्दिष्ट नोड पर संक्रमण को वापस करने के लिए किया जाता है।

समय के तरीके

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

  • transition.delay([value])- इस विधि का उपयोग संक्रमण देरी को निर्दिष्ट मूल्य पर सेट करने के लिए किया जाता है। यदि प्रत्येक चयनित तत्व के लिए एक फ़ंक्शन का मूल्यांकन किया जाता है, तो इसे वर्तमान DOM तत्व के रूप में संदर्भ के साथ वर्तमान डेटा 'd' और इंडेक्स 'i' में पास किया जाता है। यदि कोई मान निर्दिष्ट नहीं है, तो संक्रमण में पहले (गैर-अशक्त) तत्व के लिए देरी का वर्तमान मान लौटाता है। यह नीचे परिभाषित किया गया है,

transition.delay(function(d, i) { return i * 10; });
  • transition.duration([value])- इस पद्धति का उपयोग संक्रमण अवधि को निर्दिष्ट मान पर सेट करने के लिए किया जाता है। यदि कोई मान निर्दिष्ट नहीं है, तो संक्रमण में पहले (गैर-शून्य) तत्व के लिए अवधि का वर्तमान मान लौटाता है।

  • transition.ease([value])- इस विधि का उपयोग चयनित तत्वों के लिए संक्रमण मूल्य को कम करने के लिए किया जाता है। एनीमेशन के प्रत्येक फ्रेम के लिए सहजतापूर्ण फ़ंक्शन को लागू किया जाता है और सामान्यीकृत समय 'टी' को सीमा में पारित किया जाता है [0, 1]। यदि कोई मान निर्दिष्ट नहीं है, तो यह संक्रमण में पहले (गैर-शून्य) तत्व के लिए वर्तमान सहजता फ़ंक्शन को वापस करता है।

अगले अध्याय में, हम d3.js. में ड्रैग एंड ड्रॉप कॉन्सेप्ट पर चर्चा करेंगे।

खींचें और ड्रॉप d3.js. में सबसे परिचित अवधारणा में से एक है यह अध्याय विस्तार से और इसके तरीकों को विस्तार से बताता है।

इंस्टालेशन

हम निम्नलिखित स्क्रिप्ट का उपयोग करके सीधे एपीआई को खींच सकते हैं।

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

एपीआई तरीकों को खींचना

D3.js. में सबसे महत्वपूर्ण ड्रैगिंग एपीआई विधियों में से कुछ निम्नलिखित हैं

  • d3.drag()
  • drag(selection)
  • drag.container([container])
  • drag.filter([filter])
  • drag.subject([subject])
  • drag.clickDistance([distance])
  • ड्रैग.ऑन (टाइपनेम, [श्रोता])
  • d3.dragDisable(window)
  • d3.dragEnable (विंडो [, noclick])

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

d3.drag ()

इस विधि का उपयोग एक नया खींचने के लिए किया जाता है। आप निम्न स्क्रिप्ट का उपयोग करके इस विधि को कॉल कर सकते हैं।

<script>
   var drag = d3.drag();
</script>

खींचें (चयन)

निर्दिष्ट चयन के लिए ड्रैगिंग को लागू करने के लिए इस पद्धति का उपयोग किया जाता है। आप इस फ़ंक्शन का उपयोग करके आह्वान कर सकते हैंselection.call। एक सरल उदाहरण नीचे परिभाषित किया गया है।

d3.select(".node").call(d3.drag().on("drag", mousemove));

यहाँ, चयनित तत्वों पर लागू ड्रैग व्यवहार Selection.call के माध्यम से है।

drag.container([container])

इसका उपयोग कंटेनर को खींचने के लिए निर्दिष्ट फ़ंक्शन में सेट करने के लिए किया जाता है। यदि कंटेनर निर्दिष्ट नहीं है, तो यह वर्तमान एक्सेसर को लौटाता है। कैनवस के साथ किसी भी चित्रमय तत्वों को खींचने के लिए, आप कंटेनर को खुद को फिर से परिभाषित कर सकते हैं। इसे नीचे परिभाषित किया गया है।

function container() {
   return this;
}

drag.filter ([फिल्टर])

इसका उपयोग निर्दिष्ट फ़ंक्शन के लिए फ़िल्टर सेट करने के लिए किया जाता है। यदि फ़िल्टर निर्दिष्ट नहीं है, तो यह नीचे के रूप में परिभाषित वर्तमान फ़िल्टर लौटाता है।

function filter() {
   return !d3.event.button;
}

drag.subject ([विषय])

यह विषय को खींचने के लिए निर्दिष्ट फ़ंक्शन पर सेट करने के लिए उपयोग किया जाता है और नीचे परिभाषित किया गया है।

function subject(d) {
   return d = =  null ? {x: d3.event.x, y: d3.event.y} : d;
}

यहाँ, विषय वस्तु को खींचे जाने का प्रतिनिधित्व करता है। उदाहरण के लिए, यदि आप एसवीजी में आयत तत्वों को खींचना चाहते हैं, तो डिफ़ॉल्ट विषय आयत को घसीटा जा रहा है।

drag.clickDistance ([दूरी])

इस विधि का उपयोग मूसडाउन और माउसअप ईवेंट को क्लिक करने के लिए अधिकतम दूरी निर्धारित करने के लिए किया जाता है। यदि दूरी निर्दिष्ट नहीं है, तो यह शून्य की ओर इशारा करता है।

ड्रैग.ऑन (टाइपनेम, [श्रोता])

ड्रैगिंग के लिए निर्दिष्ट टाइपनेम के लिए ईवेंट श्रोता को सेट करने के लिए इस विधि का उपयोग किया जाता है। टाइपनेम एक स्ट्रिंग है जिसमें व्हॉट्सएप द्वारा अलग किए गए एक या अधिक टाइपनाम होते हैं। प्रत्येक टाइपनेम एक प्रकार है, वैकल्पिक रूप से एक अवधि (।) और एक नाम, जैसे कि drag.one और drag.two। यह प्रकार निम्नलिखित में से एक होना चाहिए -

  • start - एक नया पॉइंटर शुरू करता है।

  • drag - एक सक्रिय सूचक drags।

  • end - निष्क्रिय एक सक्रिय सूचक।

d3.dragDisable (विंडो)

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

d3.dragEnable (विंडो [, noclick])

इस पद्धति का उपयोग निर्दिष्ट विंडो स्थान पर ड्रैग और ड्रॉप चयन को सक्षम करने के लिए किया जाता है। इसका उपयोग माउसअप ईवेंट क्रिया को कॉल करने के लिए किया जाता है। यदि आप निर्दिष्ट करते हैं कि noclick मान सत्य है, तो क्लिक करें घटना एक शून्य मिलीसेकंड समय सीमा समाप्त हो रही है।

ड्रैगिंग एपीआई - ड्रैग इवेंट्स

ड्रैग इवेंट को सेट करने के लिए D3.event विधि का उपयोग किया जाता है। इसमें निम्नलिखित क्षेत्र शामिल हैं -

  • Target - यह ड्रैग व्यवहार का प्रतिनिधित्व करता है।

  • Type - यह एक स्ट्रिंग है और निम्नलिखित में से कोई भी एक हो सकता है- "स्टार्ट", "ड्रैग" या "एंड"।

  • Subject - खींचें विषय, drag.subject द्वारा परिभाषित किया गया है।

event.on (टाइपनेम, [श्रोता])

इवेंट ऑब्जेक्ट ड्रैगिंग करने के लिए event.on विधि को उजागर करता है। इसे निम्नानुसार परिभाषित किया गया है।

d3.event.on("drag", dragged).on("end", ended);

ज़ूम करने से आपकी सामग्री को स्केल करने में मदद मिलती है। आप क्लिक-एंड-ड्रैग दृष्टिकोण का उपयोग करके किसी विशेष क्षेत्र पर ध्यान केंद्रित कर सकते हैं। इस अध्याय में, हम ज़ूमिंग एपीआई पर विस्तार से चर्चा करेंगे।

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

आप निम्न स्क्रिप्ट का उपयोग करके ज़ूमिंग एपीआई को सीधे "d3js.org" से लोड कर सकते हैं।

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>
<script src = "https://d3js.org/d3-zoom.v1.min.js"></script>

<body>
   <script>
   </script>
</body>

जूमिंग एपीआई तरीके

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

  • d3.zoom()
  • zoom(selection)
  • zoom.transform (चयन, परिवर्तन)
  • zoom.translateBy (चयन, x, y)
  • zoom.translateTo (चयन, x, y)
  • zoom.scaleTo (चयन, के)
  • zoom.scaleBy (चयन, के)
  • zoom.filter([filter])
  • zoom.wheelDelta([delta])
  • zoom.extent([extent])
  • zoom.scaleExtent([extent])
  • zoom.translateExtent([extent])
  • zoom.clickDistance([distance])
  • zoom.duration([duration])
  • zoom.interpolate([interpolate])
  • zoom.on (टाइपनेम [श्रोता])

आइए हम इन सभी ज़ूमिंग एपीआई विधियों को संक्षेप में देखें।

d3.zoom ()

यह एक नया ज़ूम व्यवहार बनाता है। नीचे दी गई स्क्रिप्ट का उपयोग करके हम इसे एक्सेस कर सकते हैं।

<script>
   var zoom = d3.zoom();
</script>

ज़ूम (चयन)

इसका उपयोग चयनित तत्व पर ज़ूम परिवर्तन को लागू करने के लिए किया जाता है। उदाहरण के लिए, आप निम्न सिंटैक्स का उपयोग करके एक mousedown.zoom व्यवहार को तुरंत कर सकते हैं।

selection.call(d3.zoom().on("mousedown.zoom", mousedowned));

zoom.transform (चयन, परिवर्तन)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ूम परिवर्तन को निर्दिष्ट परिवर्तन में सेट करने के लिए किया जाता है। उदाहरण के लिए, हम नीचे दिए गए सिंटैक्स का उपयोग करके ज़ूम ट्रांसफ़ॉर्मेशन को पहचान परिवर्तन में रीसेट कर सकते हैं।

selection.call(zoom.transform, d3.zoomIdentity);

हम निम्नलिखित सिंटैक्स का उपयोग करके 1000 मिलीसेकंड के लिए पहचान परिवर्तन के ज़ूम परिवर्तन को भी रीसेट कर सकते हैं।

selection.transition().duration(1000).call(zoom.transform, d3.zoomIdentity);

zoom.translateBy (चयन, x, y)

यह x और y मानों द्वारा चयनित तत्वों के वर्तमान ज़ूम ट्रांसफ़ॉर्मेशन का अनुवाद करने के लिए उपयोग किया जाता है। आप संख्याओं के रूप में या संख्याओं के रूप में x और y अनुवाद मान निर्दिष्ट कर सकते हैं। यदि किसी कार्य को चयनित तत्व के लिए लागू किया जाता है, तो यह DOM के लिए वर्तमान डेटा 'd' और इंडेक्स 'i' से होकर गुजरता है। एक नमूना कोड नीचे परिभाषित किया गया है।

zoom.translateBy(selection, x, y) {
   zoom.transform(selection, function() {
      return constrain(this.__zoom.translate(
         x = = = "function" ? x.apply(this, arguments) : x,
         y = = = "function" ? y.apply(this, arguments) : y
      );
   }
};

zoom.translateTo (चयन, x, y)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ूम परिवर्तन को x और y की निर्दिष्ट स्थिति में अनुवाद करने के लिए किया जाता है।

zoom.scaleTo (चयन, के)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ूम परिवर्तन को स्केल करने के लिए किया जाता है k। यहाँ,k एक स्केल फैक्टर है, जो संख्याओं या कार्यों के रूप में निर्दिष्ट है।

zoom.scaleTo = function(selection, k) {
   zoom.transform(selection, function() {
      k = = = "function" ? k.apply(this, arguments) : k;
   });
};

zoom.scaleBy (चयन, के)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ून परिवर्तन को मापने के लिए किया जाता है k। यहाँ,k एक पैमाना कारक है, जो संख्याओं के रूप में या फ़ंक्शंस के रूप में निर्दिष्ट होता है जो संख्याएँ लौटाता है।

zoom.scaleBy = function(selection, k) {
   zoom.scaleTo(selection, function() {
      var k0 = this.__zoom.k,
      k1 = k = = = "function" ? k.apply(this, arguments) : k;
      return k0 * k1;
   });
};

zoom.filter ([फिल्टर])

यह जूम व्यवहार के लिए फ़िल्टर को निर्दिष्ट फ़ंक्शन पर सेट करने के लिए उपयोग किया जाता है। यदि फ़िल्टर निर्दिष्ट नहीं है, तो यह नीचे दिखाए अनुसार वर्तमान फ़िल्टर लौटाता है।

function filter() {
   return !d3.event.button;
}

zoom.wheelDelta ([डेल्टा])

का मूल्य Δव्हील डेल्टा फ़ंक्शन द्वारा लौटाया गया है। यदि डेल्टा निर्दिष्ट नहीं है, तो यह वर्तमान व्हील डेल्टा फ़ंक्शन लौटाता है।

zoom.extent ([हद])

इसका उपयोग निर्दिष्ट सरणी बिंदुओं की सीमा निर्धारित करने के लिए किया जाता है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान सीमा अभिगमकर्ता को लौटाता है, जो कि [[0, 0], [चौड़ाई, ऊंचाई]] में चूक करता है, जहां चौड़ाई तत्व की चौड़ाई है और ऊंचाई इसकी क्लाइंट ऊंचाई है।

zoom.scaleExtent ([हद])

इसका उपयोग पैमाने की निर्दिष्ट संख्या के पैमाने को निर्धारित करने के लिए किया जाता है [k0, k1]। यहाँ,k0न्यूनतम अनुमत पैमाना कारक है। जबकि,k1अधिकतम अनुमत पैमाना कारक है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान पैमाने की सीमा लौटाता है, जो चूक [0,,] के लिए है। नमूना कोड पर विचार करें जो नीचे परिभाषित किया गया है।

selection
   .call(zoom)
   .on("wheel", function() { d3.event.preventDefault(); });

उपयोगकर्ता पहले से ही स्केल की सीमा के अनुरूप होने पर, व्हीलिंग द्वारा ज़ूम करने का प्रयास कर सकता है। अगर हम स्केल की परवाह किए बिना व्हील इनपुट पर स्क्रॉल को रोकना चाहते हैं, तो ब्राउज़र डिफ़ॉल्ट व्यवहार को रोकने के लिए व्हील इवेंट श्रोता को पंजीकृत करें।

zoom.translateExtent ([हद])

यदि सीमा निर्दिष्ट है, तो यह अनुवाद की सीमा निर्दिष्ट बिंदुओं तक निर्धारित करता है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान अनुवाद सीमा को लौटाता है, जो कि [[-∞, -∞], [+ ∞, + ∞] में चूक करता है।

zoom.clickDistance ([दूरी])

इस पद्धति का उपयोग अधिकतम दूरी निर्धारित करने के लिए किया जाता है, जो ज़ूम करने योग्य क्षेत्र ऊपर और नीचे के बीच स्थानांतरित हो सकता है, जो बाद के क्लिक इवेंट को ट्रिगर करेगा।

zoom.duration ([अवधि])

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

selection
   .call(zoom)
   .on("dblclick.zoom", null);

zoom.interpolate ([लगाना])

इस विधि का उपयोग ज़ूम फ़ंक्शन के लिए निर्दिष्ट फ़ंक्शन के लिए प्रक्षेप करने के लिए किया जाता है। यदि इंटरपोल को निर्दिष्ट नहीं किया जाता है, तो यह वर्तमान इंटरपोलेशन फैक्ट्री को लौटाता है, जो d3.interpolateZoom को डिफॉल्ट करता है।

zoom.on (टाइपनेम [श्रोता])

यदि श्रोता निर्दिष्ट किया जाता है, तो यह निर्धारित श्रोता के लिए ईवेंट श्रोता को सेट करता है और ज़ूम व्यवहार लौटाता है। टाइपनेम एक स्ट्रिंग है जिसमें व्हॉट्सएप द्वारा अलग किए गए एक या अधिक टाइपनाम होते हैं। प्रत्येक टाइपनेम एक प्रकार है, वैकल्पिक रूप से एक अवधि (।) और एक नाम, जैसे कि zoom.one और zoom.second। नाम कई श्रोताओं को एक ही प्रकार के लिए पंजीकृत होने की अनुमति देता है। यह प्रकार निम्नलिखित में से एक होना चाहिए -

  • Start - ज़ूमिंग शुरू होने के बाद (जैसे कि मूसडाउन पर)।

  • Zoom - जूम ट्रांसफॉर्मेशन में बदलाव के बाद (जैसे mousemove पर)।

  • End - ज़ूमिंग समाप्त होने के बाद (जैसे माउसअप पर)।

अगले अध्याय में, हम D3.js. में विभिन्न अनुरोध एपीआई पर चर्चा करेंगे।

D3.js XMLHttpRequest करने के लिए एक अनुरोध API प्रदान करता है। यह अध्याय एपीआई के विभिन्न अनुरोधों के बारे में विस्तार से बताता है।

XMLHttpRequest

XMLHttpRequest ब्राउज़र XMLHttpRequest ऑब्जेक्ट का अनुकरण करने के लिए अंतर्निहित http क्लाइंट है। इसका उपयोग कोड के पुन: उपयोग में सुधार करने और मौजूदा पुस्तकालयों के उपयोग की अनुमति देने के लिए ब्राउज़रों के लिए डिज़ाइन किए गए JS के साथ किया जा सकता है।

आप अपनी परियोजना में मॉड्यूल को शामिल कर सकते हैं और नीचे बताए अनुसार ब्राउज़र-आधारित एक्सएचआर ऑब्जेक्ट के रूप में उपयोग कर सकते हैं।

var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
var xhr = new XMLHttpRequest();

यह async और सिंक्रोनस दोनों अनुरोधों का समर्थन करता है और यह GET, POST, PUT और DELETE अनुरोध करता है।

अनुरोधों को कॉन्फ़िगर करना

आप नीचे दी गई स्क्रिप्ट का उपयोग करके सीधे "d3js.org" से लोड कर सकते हैं।

<script src = "https://d3js.org/d3-request.v1.min.js"></script>
<script>
   d3.json("/path/to/sample.json", callback);
</script>

यहां, अनुरोध एपीआई ने JSON, CSV और TSV को पार्स करने के लिए अंतर्निहित समर्थन किया है। आप सीधे अनुरोध या पाठ का उपयोग करके अतिरिक्त स्वरूपों को पार्स कर सकते हैं।

पाठ फ़ाइलें लोड करें

पाठ फ़ाइल लोड करने के लिए, निम्नलिखित सिंटैक्स का उपयोग करें।

d3.text("/path/to/sample.txt", function(error, text) {
   if (error) throw error;
   console.log(text); 
});

CSV फ़ाइलों को पार्स करना

CSV फ़ाइल लोड और पार्स करने के लिए, निम्नलिखित सिंटैक्स का उपयोग करें।

d3.csv("/path/to/sample.csv", function(error, data) {
   if (error) throw error;
   console.log(data); 
});

इसी तरह, आप JSON और TSV फ़ाइलों को भी लोड कर सकते हैं।

काम करने का उदाहरण

CSV फ़ाइल लोड और पार्स कैसे करें, इसके लिए एक सरल उदाहरण के माध्यम से चलते हैं। इससे पहले, आपको नीचे दिखाए गए अनुसार अपने d3 एप्लिकेशन फ़ोल्डर में "sample.csv" नामक एक सीएसवी फ़ाइल बनाने की आवश्यकता है।

Num1,Num2
1,2
3,4
5,6
7,8
9,10

अब, निम्नलिखित स्क्रिप्ट का उपयोग करके एक वेबपेज "request.html" बनाएं।

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

   <body>
      <h3> D3.js Requests API </h3>
      <script>
         d3.csv("sample.csv", function(data) {
            console.log(data); 
         });
      </script>
   </body>
</html>

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

अनुरोध एपीआई तरीके

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

  • d3.request (url [, callback])
  • request.header (नाम [, मान])
  • request.mimeType([type])
  • request.user([value])
  • request.password([value])
  • request.timeout([timeout])
  • request.get([data])
  • request.post([data])
  • request.send (विधि [, डेटा])
  • request.abort()
  • d3.csv (url [[, पंक्ति], कॉलबैक])

आइए अब हम संक्षेप में इनमें से प्रत्येक पर चर्चा करते हैं।

d3.request (url [, callback])

यह दिए गए URL के लिए एक नया अनुरोध देता है। यदि कॉलबैक असाइन किया गया है, तो इसे कॉलिंग अनुरोध माना जाता है अन्यथा अनुरोध अभी तक नहीं कहा जाता है। इसे नीचे परिभाषित किया गया है।

d3.request(url)
   .get(callback);

आप निम्नलिखित सिंटैक्स का उपयोग करके कुछ क्वेरी पैरामीटर पोस्ट कर सकते हैं।

d3.request("/path/to/resource")
   .header("X-Requested-With", "XMLHttpRequest")
   .header("Content-Type", "application/x-www-form-urlencoded")
   .post("a = 2&b = 3", callback);

यदि आप एक अनुरोध शीर्ष लेख या माइम प्रकार निर्दिष्ट करना चाहते हैं, तो आपको निर्माता को कॉलबैक निर्दिष्ट नहीं करना चाहिए।

request.header (नाम [, मान])

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

d3.request(url)
   .header("Accept-Language", "en-US")
   .header("X-Requested-With", "XMLHttpRequest")
   .get(callback);

यहाँ, X-Requested-With हैडर से XMLHttpRequest एक डिफ़ॉल्ट अनुरोध है।

request.mimeType ([प्रकार])

इसका उपयोग माइम प्रकार को दिए गए मान को निर्दिष्ट करने के लिए किया जाता है। इसे नीचे परिभाषित किया गया है।

d3.request(url)
   .mimeType("text/csv")
   .get(callback);

request.user ([value])

इसका उपयोग प्रमाणीकरण के लिए उपयोगकर्ता नाम निर्दिष्ट करने के लिए किया जाता है। यदि कोई उपयोगकर्ता नाम निर्दिष्ट नहीं है, तो यह अशक्त करने के लिए चूक है।

request.password ([value])

यदि कोई मान निर्दिष्ट किया गया है, तो वह प्रमाणीकरण के लिए पासवर्ड सेट करता है।

request.timeout ([टाइमआउट])

यदि कोई टाइमआउट निर्दिष्ट किया गया है, तो यह टाइमआउट को मिलीसेकंड की निर्दिष्ट संख्या पर सेट करता है।

request.get ([डेटा])

इस विधि का उपयोग GET विधि के साथ अनुरोध भेजने के लिए किया जाता है। इसे नीचे परिभाषित किया गया है।

request.send("GET", data, callback);

request.post ([डेटा])

इस विधि का उपयोग POST विधि के साथ अनुरोध भेजने के लिए किया जाता है। इसे नीचे परिभाषित किया गया है।

request.send("POST", data, callback);

request.send (विधि [, डेटा])

इस विधि का उपयोग दिए गए GET या POST विधि का उपयोग करके अनुरोध भेजने के लिए किया जाता है।

request.abort ()

अनुरोध को निरस्त करने के लिए इस विधि का उपयोग किया जाता है।

d3.csv (url [[, पंक्ति], कॉलबैक])

डिफ़ॉल्ट Mime प्रकार पाठ / csv के साथ निर्दिष्ट URL पर CSV फ़ाइल के लिए एक नया अनुरोध लौटाता है। निम्न सिंटैक्स बिना कॉलबैक के दिखाता है।

d3.request(url)
   .mimeType("text/csv")
   .response(function(xhr) { return d3.csvParse(xhr.responseText, row); });

यदि आप POST विधि के साथ कॉलबैक निर्दिष्ट करते हैं, तो यह नीचे परिभाषित किया गया है।

d3.request(url)
   .mimeType("text/csv")
   .response(function(xhr) { return d3.csvParse(xhr.responseText, row); })
   .post(callback);

उदाहरण

अपने d3 एप्लिकेशन रूट फ़ोल्डर निर्देशिका में "lang.csv" नामक एक सीएसवी फ़ाइल बनाएं और इसमें निम्न परिवर्तन जोड़ें।

Year,Language,Author
1972,C,Dennis Ritchie
1995,Java,James gosling
2011,D3 js,Mike Bostock

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

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

   <body>
      <h3> D3.js request API</h3>
      <script>
         d3.csv("lang.csv", function(d) {
            return {
               year: new Date(+d.Year, 0, 1), // convert "Year" column to Date
               language: d.Language,
               author: d.Author,
            };
         }, function(error, rows) {
            console.log(error);
            console.log(rows[0].year);
         });
      </script>
   </body>
</html>

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

एक सीमांकक एक या एक से अधिक वर्णों का एक क्रम है जिसका उपयोग सादे पाठ या अन्य डेटा में अलग, स्वतंत्र क्षेत्रों के बीच सीमा को निर्दिष्ट करने के लिए किया जाता है। एक फ़ील्ड सीमांकक अल्पविराम द्वारा अलग किए गए मानों का एक क्रम है। खैर, सीमांत-पृथक मूल्य हैंcomma separated values (CSV) या tab-separated values(TSV)। यह अध्याय विस्तार से अलग किए गए मानों की व्याख्या करता है।

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

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

<script src = "https://d3js.org/d3-dsv.v1.min.js"></script>
<script>
   var data = d3.csvParse(string);
</script>

एपीआई तरीके

निम्नलिखित सीमांकित-पृथक मानों के विभिन्न एपीआई तरीके हैं।

  • d3.csvParse (स्ट्रिंग [, पंक्ति])
  • d3.csvParseRows (स्ट्रिंग [, पंक्ति])
  • d3.csvFormat (पंक्तियाँ [, कॉलम])
  • d3.csvFormatRows(rows)
  • d3.tsvParse (स्ट्रिंग [, पंक्ति])
  • d3.tsvParseRows (स्ट्रिंग [, पंक्ति])
  • d3.tsvFormat (पंक्तियाँ [, कॉलम])
  • d3.tsvFormatRows(rows)

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

d3.csvParse (स्ट्रिंग [, पंक्ति])

इस विधि का उपयोग csv प्रारूप को पार्स करने के लिए किया जाता है। फ़ाइल पर विचार करेंdata.csv वह नीचे दिखाया गया है।

year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62

अब, हम ऊपर दिए गए फ़ंक्शन को लागू कर सकते हैं।

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

var data = d3.csvParse(string, function(d) {
   return {
      year: new Date(+d.Year, 0, 1), // lowercase and convert "Year" to Date
      population: d.population
   };
});

यहाँ, यह निर्दिष्ट स्ट्रिंग को सीमांकित-पृथक मानों में बताता है। यह पार्स की गई पंक्तियों का प्रतिनिधित्व करने वाली वस्तुओं की एक सरणी देता है।

d3.csvParseRows (स्ट्रिंग [, पंक्ति])

इस विधि का उपयोग पंक्तियों के बराबर सीएसवी प्रारूप को पार्स करने के लिए किया जाता है।

var data = d3.csvParseRows(string, function(d, i) {
   return {
      year: new Date(+d[0], 0, 1), // convert first colum column to Date
      population: d[1],
   };
});

यह csv फ़ाइल में प्रत्येक पंक्ति को पार्स करता है।

d3.csvFormat (पंक्तियाँ [, कॉलम])

इस विधि का उपयोग सीएसवी पंक्तियों और स्तंभों को प्रारूपित करने के लिए किया जाता है।

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

var string = d3.csvFormat(data, ["year", "population"]);

यहां, यदि कॉलम निर्दिष्ट नहीं किए गए हैं, तो हेडर पंक्ति बनाने वाले कॉलम नामों की सूची पंक्तियों में सभी वस्तुओं पर सभी गुणों के संघ द्वारा निर्धारित की जाती है। यदि कॉलम निर्दिष्ट हैं, तो यह स्तंभ नामों का प्रतिनिधित्व करने वाले तारों का एक सरणी है।

d3.csvFormatRows (पंक्तियाँ)

इस विधि का उपयोग सीएसवी पंक्तियों को प्रारूपित करने के लिए किया जाता है।

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

var string = d3.csvFormatRows(data.map(function(d, i) {
   return [
      d.year.getFullYear(), // Assuming d.year is a Date object.
      d.population
   ];
}));

यहां, यह स्ट्रिंग पंक्तियों के निर्दिष्ट सरणी को सीमांकित-पृथक मानों के रूप में प्रारूपित करता है, एक स्ट्रिंग लौटाता है।

d3.tsvParse (स्ट्रिंग [, पंक्ति])

इस विधि का उपयोग tsv प्रारूप को पार्स करने के लिए किया जाता है। यह csvParse के समान है।

d3.tsvParseRows (स्ट्रिंग [, पंक्ति])

इस विधि का उपयोग पंक्तियों के बराबर tvv प्रारूप को पार्स करने के लिए किया जाता है। यह csvParseRows फ़ंक्शन के समान है।

d3.tsvFormat (पंक्तियाँ [, कॉलम])

इस विधि का उपयोग tsv पंक्तियों और स्तंभों को प्रारूपित करने के लिए किया जाता है।

d3.tsvFormatRows (पंक्तियाँ)

इस विधि का उपयोग tsv पंक्तियों को प्रारूपित करने के लिए किया जाता है।

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

requestAnimationFrame

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

टाइमर को कॉन्फ़िगर करना

हम निम्नलिखित स्क्रिप्ट का उपयोग करके आसानी से सीधे d3js.org से टाइमर लोड कर सकते हैं।

<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script>
   var timer = d3.timer(callback);
</script>

टाइमर एपीआई तरीके

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

d3.now ()

यह विधि वर्तमान समय को लौटाती है।

d3.timer (कॉलबैक [, देरी [, समय]])

इस पद्धति का उपयोग नए टाइमर को शेड्यूल करने के लिए किया जाता है और टाइमर को बंद होने तक चालान करता है। आप MS में सांख्यिक विलंब सेट कर सकते हैं, लेकिन यह वैकल्पिक है अन्यथा, यह शून्य पर डिफॉल्ट करता है। यदि समय निर्दिष्ट नहीं है, तो इसे d3.now () माना जाता है।

टाइमर.स्टार्ट (कॉलबैक [, देरी [, समय]])

निर्दिष्ट कॉलबैक और वैकल्पिक देरी और समय के साथ एक टाइमर को पुनरारंभ करें।

timer.stop ()

यह विधि टाइमर को रोकती है, बाद के कॉलबैक को रोकती है।

d3.time (कॉलबैक [, देरी [, समय]])

इसका उपयोग अपने पहले कॉलबैक पर टाइमर को रोकने के लिए किया जाता है। कॉलबैक बीता हुआ समय माना जाता है।

d3.interval (कॉलबैक [, देरी [, समय]])

यह एक विशेष समय विलंब अंतराल पर लगाया जाता है। यदि देरी निर्दिष्ट नहीं है, तो यह टाइमर समय लेता है।

उदाहरण

एक वेबपेज "टाइमर.html" बनाएं और इसमें निम्न स्क्रिप्ट जोड़ें।

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

   <body>
      <h3> Timer API </h3>
      <script>
         var timer = d3.timer(function(duration) {
            console.log(duration);
            if (duration > 150) timer.stop();
         }, 100);
      </script>
   </body>
</html>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

आइए इस अध्याय में एक एनिमेटेड बार चार्ट का प्रदर्शन करें। इस उदाहरण के लिए, हम डेटा रिकॉर्ड में उपयोग किए गए डेटा.csv को जनसंख्या रिकॉर्ड के पिछले अध्याय में डेटासेट के रूप में लेते हैं और एक एनिमेटेड बार चार्ट उत्पन्न करते हैं।

ऐसा करने के लिए, हमें निम्नलिखित चरण करने होंगे -

Step 1 - Apply styles - नीचे दिए गए कोडिंग का उपयोग करके सीएसएस शैलियों को लागू करें।

<style>
   .bar {
      fill: green;
   }
   
   .highlight {
      fill: red;
   }
   
   .title {
      fill: blue;
      font-weight: bold;
   }
</style>

Step 2 - Define variables - नीचे स्क्रिप्ट का उपयोग करके एसवीजी विशेषताओं को परिभाषित करते हैं।

<script>
   var svg = d3.select("svg"), margin = 200,
   width = svg.attr("width") - margin,
   height = svg.attr("height") - margin;
</script>

Step 3 - Append text - अब, पाठ जोड़ें और नीचे कोडिंग का उपयोग करके परिवर्तन लागू करें।

svg.append("text")
   .attr("transform", "translate(100,0)")
   .attr("x", 50)
   .attr("y", 50)
   .attr("font-size", "20px")
   .attr("class", "title")
   .text("Population bar chart")

Step 4 - Create scale range- इस चरण में, हम एक स्केल रेंज बना सकते हैं और समूह तत्वों को जोड़ सकते हैं। इसे नीचे परिभाषित किया गया है।

var x = d3.scaleBand().range([0, width]).padding(0.4),
   y = d3.scaleLinear()
      .range([height, 0]);
   var g = svg.append("g")
      .attr("transform", "translate(" + 100 + "," + 100 + ")");

Step 5 - Read data - हम पहले ही बना चुके हैं data.csvहमारे पिछले उदाहरणों में फ़ाइल करें। वही फाइल, जिसका हमने यहां उपयोग किया है।

year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62

अब, नीचे दिए गए कोड का उपयोग करके उपरोक्त फ़ाइल पढ़ें।

d3.csv("data.csv", function(error, data) {
   if (error) {
      throw error;
   }

Step 6 - Set domain - अब, नीचे दिए गए कोडिंग का उपयोग करके डोमेन सेट करें।

x.domain(data.map(function(d) { return d.year; }));
y.domain([0, d3.max(data, function(d) { return d.population; })]);

Step 7 - Add X-axis- अब, आप परिवर्तन में एक्स-अक्ष जोड़ सकते हैं। इसे नीचे दिखाया गया है।

g.append("g")
   .attr("transform", "translate(0," + height + ")")
   .call(d3.axisBottom(x)).append("text")
   .attr("y", height - 250).attr("x", width - 100)
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("year");

Step 8 - Add Y-axis - नीचे दिए गए कोड का उपयोग करके परिवर्तन में Y- अक्ष जोड़ें।

g.append("g")
   .append("text").attr("transform", "rotate(-90)")
   .attr("y", 6).attr("dy", "-5.1em")
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("population");

Step 9 - Append group elements - अब, समूह तत्वों को जोड़ दें और नीचे बताए अनुसार Y- अक्ष में परिवर्तन लागू करें।

g.append("g")
   .attr("transform", "translate(0, 0)")
   .call(d3.axisLeft(y))

Step 10 - Select the bar class - अब, नीचे दिए गए अनुसार बार वर्ग के सभी तत्वों का चयन करें।

g.selectAll(".bar")
   .data(data).enter()
   .append("rect")
   .attr("class", "bar")
   .on("mouseover", onMouseOver) 
   .on("mouseout", onMouseOut)
   .attr("x", function(d) { return x(d.year); })
   .attr("y", function(d) { return y(d.population); })
   .attr("width", x.bandwidth())
   .transition()
   .ease(d3.easeLinear)
   .duration(200)
   .delay(function (d, i) {
      return i * 25;
   })
   .attr("height", function(d) { return height - y(d.population); });
});

यहां, हमने माउसआउट और माउसओवर के लिए श्रोता को एनीमेशन प्रदर्शन के लिए जोड़ा। यह एनीमेशन लागू होता है, जब माउस एक विशेष पट्टी पर घूमता है और इससे बाहर निकल जाता है। इन कार्यों को निम्नलिखित चरण में समझाया गया है।

.ease(d3.easeLinear)फ़ंक्शन का उपयोग एनीमेशन में स्पष्ट गति करने के लिए किया जाता है। यह 200 की अवधि के साथ धीमी गति से और धीमी गति वाली गति को संसाधित करता है। विलंब का उपयोग करके गणना की जा सकती है -

.delay(function (d, i) {
   return i * 25;
})

Step 11 - Mouseover event handler function - नीचे दिखाए गए अनुसार माउस घटना को संभालने के लिए एक माउसओवर ईवेंट हैंडलर बनाएं।

function onMouseOver(d, i) {
   d3.select(this)
      .attr('class', 'highlight');
   d3.select(this)
      .transition()
      .duration(200)
      .attr('width', x.bandwidth() + 5)
      .attr("y", function(d) { return y(d.population) - 10; })
      .attr("height", function(d) { return height - y(d.population) + 10; });
   g.append("text")
      .attr('class', 'val') 
   
   .attr('x', function() {
      return x(d.year);
   })
   
   .attr('y', function() {
      return y(d.value) - 10;
   })
}

यहाँ, माउसओवर इवेंट में, हम बार की चौड़ाई और ऊँचाई और चयनित बार के रंग को लाल करना चाहते हैं। रंग के लिए, हमने एक वर्ग 'हाइलाइट' जोड़ा है, जो चयनित बार का रंग बदलकर लाल कर देता है।

200 मिलीसेकंड की अवधि के लिए बार में एक संक्रमण कार्य। जब हम बार की चौड़ाई 5px और ऊंचाई 10px बढ़ाते हैं, तो पिछली चौड़ाई और बार की नई चौड़ाई और ऊँचाई से संक्रमण 200 मिलीसेकंड की अवधि के लिए होगा।

अगला, हमने बार को एक नए 'y' मान की गणना की, ताकि बार नई ऊंचाई के कारण बार विकृत न हो।

Step 12 - Mouseout event handler function- आइए हम माउस ईवेंट हैंडल करने के लिए माउसआउट इवेंट हैंडलर बनाएं। इसे नीचे परिभाषित किया गया है।

function onMouseOut(d, i) {
   d3.select(this).attr('class', 'bar');
   
   d3.select(this)
      .transition()     
      .duration(400).attr('width', x.bandwidth())
      .attr("y", function(d) { return y(d.population); })
      .attr("height", function(d) { return height - y(d.population); });
   
   d3.selectAll('.val')
      .remove()
}

यहां, माउसआउट इवेंट में, हम उन चयन सुविधाओं को हटाना चाहते हैं, जिन्हें हमने माउसओवर इवेंट में लागू किया था। इसलिए, हम बार वर्ग को मूल 'बार' वर्ग में वापस लाते हैं और चयनित बार की मूल चौड़ाई और ऊंचाई को पुनर्स्थापित करते हैं और मूल मान के लिए y मान को पुनर्स्थापित करते हैं।

d3.selectAll(‘.val’).remove() फ़ंक्शन का उपयोग बार चयन के दौरान हमारे द्वारा जोड़े गए पाठ मान को निकालने के लिए किया जाता है।

Step 13 - Working Example- पूरा कार्यक्रम निम्नलिखित कोड ब्लॉक में दिया गया है। एक वेबपेज बनाएंanimated_bar.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<!DOCTYPE html>
<html>
   <head>
      <style>
         .bar {
            fill: green;
         }
        
         .highlight {
            fill: red;
         }
         
         .title {
            fill: blue;
            font-weight: bold;
         }
      </style>
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <title> Animated bar chart </title>
   </head>

   <body>
      <svg width = "500" height = "500"></svg>
      <script>
         var svg = d3.select("svg"),
         margin = 200, width = svg.attr("width") - margin,
         height = svg.attr("height") - margin;
         
         svg.append("text")
            .attr("transform", "translate(100,0)")
            .attr("x", 50).attr("y", 50)
            .attr("font-size", "20px")
            .attr("class", "title")
            .text("Population bar chart")
            
         var x = d3.scaleBand().range([0, width]).padding(0.4),
         y = d3.scaleLinear().range([height, 0]);
            
         var g = svg.append("g")
            .attr("transform", "translate(" + 100 + "," + 100 + ")");

         d3.csv("data.csv", function(error, data) {
            if (error) {
               throw error;
            }
               
            x.domain(data.map(function(d) { return d.year; }));
            y.domain([0, d3.max(data, function(d) { return d.population; })]);
                     
            g.append("g")
               .attr("transform", "translate(0," + height + ")")
               .call(d3.axisBottom(x))
               .append("text")
               .attr("y", height - 250)
               .attr("x", width - 100)
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue").text("year");
               
            g.append("g")
               .append("text")
               .attr("transform", "rotate(-90)")
               .attr("y", 6)
               .attr("dy", "-5.1em")
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue")
               .text("population");
                         
            g.append("g")
               .attr("transform", "translate(0, 0)")
               .call(d3.axisLeft(y))

            g.selectAll(".bar")
               .data(data)
               .enter()
               .append("rect")
               .attr("class", "bar")
               .on("mouseover", onMouseOver) 
               .on("mouseout", onMouseOut)   
               .attr("x", function(d) { return x(d.year); })
               .attr("y", function(d) { return y(d.population); })
               .attr("width", x.bandwidth()).transition()
               .ease(d3.easeLinear).duration(200)
               .delay(function (d, i) {
                  return i * 25;
               })
                  
            .attr("height", function(d) { return height - y(d.population); });
         });
          
          
         function onMouseOver(d, i) {
            d3.select(this)
            .attr('class', 'highlight');
               
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth() + 5)
               .attr("y", function(d) { return y(d.population) - 10; })
               .attr("height", function(d) { return height - y(d.population) + 10; });
              
            g.append("text")
               .attr('class', 'val')
               .attr('x', function() {
                  return x(d.year);
               })
               
            .attr('y', function() {
               return y(d.value) - 10;
            })
         }
          
         function onMouseOut(d, i) {
             
            d3.select(this)
               .attr('class', 'bar');
            
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth())
               .attr("y", function(d) { return y(d.population); })
               .attr("height", function(d) { return height - y(d.population); });
            
            d3.selectAll('.val')
               .remove()
         }
      </script>
   </body>
</html>

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

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