डी 3.जेएस - अनुरोध एपीआई

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>

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