D3.js - अवधारणाओं

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

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

वेब मानक

इससे पहले कि हम विज़ुअलाइज़ेशन बनाने के लिए 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 को सपोर्ट करते हैं। डेटा विज़ुअलाइज़ेशन दृश्य प्रतिनिधित्व हैं और यह एसवीजी का उपयोग करने के लिए डी 3 का उपयोग करके विज़ुअलाइज़ेशन को प्रस्तुत करना सुविधाजनक है।

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

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

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

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200"></rect>
</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. के लिए एक शर्त है