XML डोम - लोड हो रहा है

इस अध्याय में, हम XML लोडिंग और पार्सिंग के बारे में अध्ययन करेंगे ।

एपीआई द्वारा प्रदान किए गए इंटरफेस का वर्णन करने के लिए, W3C एक सार भाषा का उपयोग करता है जिसे इंटरफेस डेफिनिशन लैंग्वेज (IDL) कहा जाता है। IDL का उपयोग करने का लाभ यह है कि डेवलपर सीखता है कि DOM का उपयोग अपनी पसंदीदा भाषा के साथ कैसे किया जा सकता है और किसी अन्य भाषा में आसानी से स्विच किया जा सकता है।

नुकसान यह है कि, क्योंकि यह सार है, आईडीएल का उपयोग सीधे वेब डेवलपर्स द्वारा नहीं किया जा सकता है। प्रोग्रामिंग भाषाओं के बीच अंतर के कारण, उन्हें अमूर्त इंटरफेस और उनकी ठोस भाषाओं के बीच - या मैपिंग करने की आवश्यकता होती है। DOM को जावास्क्रिप्ट लैंग्वेज, JScript, Java, C, C ++, PLSQL, Python और Perl जैसे प्रोग्रामिंग लैंग्वेज में मैप किया गया है।

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

पार्सर

एक पार्सर एक सॉफ़्टवेयर एप्लिकेशन है जिसे एक दस्तावेज़ का विश्लेषण करने के लिए, हमारे मामले में XML दस्तावेज़ और जानकारी के साथ कुछ विशिष्ट करने के लिए डिज़ाइन किया गया है। डीओएम आधारित पार्सरों में से कुछ निम्नलिखित तालिका में सूचीबद्ध हैं -

S.No पार्सर और विवरण
1

JAXP

एक्सएमएल पार्सिंग (JAXP) के लिए सन माइक्रोसिस्टम्स जावा एपीआई

2

XML4J

Java के लिए IBM का XML पार्सर (XML4J)

3

msxml

Microsoft का XML पार्सर (msxml) संस्करण 2.0 इंटरनेट एक्सप्लोरर 5.5 में बनाया गया है

4

4DOM

4DOM पायथन प्रोग्रामिंग भाषा के लिए एक पार्सर है

5

XML::DOM

XML :: DOM पर्ल का उपयोग करके XML दस्तावेजों में हेरफेर करने के लिए एक पर्ल मॉड्यूल है

6

Xerces

Apache's Xerces Java Parser

DOM जैसे ट्री-आधारित API में, पार्सर XML फ़ाइल को ट्रैवर्स करता है और संबंधित DOM ऑब्जेक्ट बनाता है। फिर आप DOM संरचना को आगे-पीछे कर सकते हैं।

लोड हो रहा है और एक्सएमएल पार्सिंग

XML दस्तावेज़ लोड करते समय, XML सामग्री दो रूपों में आ सकती है -

  • सीधे XML फ़ाइल के रूप में
  • एक्सएमएल स्ट्रिंग के रूप में

XML फ़ाइल के रूप में सामग्री

निम्न उदाहरण दर्शाता है कि XML सामग्री को XML फ़ाइल के रूप में प्राप्त करने पर Ajax और जावास्क्रिप्ट का उपयोग करके XML ( नोड. xml ) डेटा को कैसे लोड किया जाए । यहाँ, Ajax फ़ंक्शन को xml फ़ाइल की सामग्री मिलती है और इसे XML DOM में संग्रहीत किया जाता है। एक बार DOM ऑब्जेक्ट बन जाने के बाद, इसे पार्स किया जाता है।

<!DOCTYPE html>
<html>
   <body>
      <div>
         <b>FirstName:</b> <span id = "FirstName"></span><br>
         <b>LastName:</b> <span id = "LastName"></span><br>
         <b>ContactNo:</b> <span id = "ContactNo"></span><br>
         <b>Email:</b> <span id = "Email"></span>
      </div>
      <script>
         //if browser supports XMLHttpRequest
            
            if (window.XMLHttpRequest) { // Create an instance of XMLHttpRequest object. 
               code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp  =  new XMLHttpRequest();
            } else { // code for IE6, IE5 
               xmlhttp  =  new ActiveXObject("Microsoft.XMLHTTP");
            }
   
         // sets and sends the request for calling "node.xml"
            xmlhttp.open("GET","/dom/node.xml",false);
            xmlhttp.send();

         // sets and returns the content as XML DOM
            xmlDoc = xmlhttp.responseXML;

         //parsing the DOM object
            document.getElementById("FirstName").innerHTML = 
               xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
            document.getElementById("LastName").innerHTML = 
               xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
            document.getElementById("ContactNo").innerHTML = 
               xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0].nodeValue;
            document.getElementById("Email").innerHTML = 
               xmlDoc.getElementsByTagName("Email")[0].childNodes[0].nodeValue;
      </script>
   </body>
</html>

node.xml

<Company> 
   <Employee category = "Technical" id = "firstelement"> 
      <FirstName>Tanmay</FirstName> 
      <LastName>Patil</LastName> 
      <ContactNo>1234567890</ContactNo> 
      <Email>[email protected]</Email> 
   </Employee>  
   
   <Employee category = "Non-Technical"> 
      <FirstName>Taniya</FirstName> 
      <LastName>Mishra</LastName> 
      <ContactNo>1234667898</ContactNo> 
      <Email>[email protected]</Email> 
   </Employee>  
   
   <Employee category = "Management"> 
      <FirstName>Tanisha</FirstName> 
      <LastName>Sharma</LastName> 
      <ContactNo>1234562350</ContactNo> 
      <Email>[email protected]</Email> 
   </Employee> 
</Company>

कोड का अधिकांश विवरण स्क्रिप्ट कोड में होता है।

  • XMLHttpRequest ऑब्जेक्ट का एक उदाहरण बनाने के लिए इंटरनेट एक्सप्लोरर ActiveXObject ("Microsoft.XMLHTTP") का उपयोग करता है, अन्य ब्राउज़र XMLHttpRequest () विधि का उपयोग करते हैं ।

  • responseXML एक्सएमएल डोम में सीधे XML सामग्री बदल देती है।

  • एक बार XML सामग्री जावास्क्रिप्ट एक्सएमएल डोम में बदल जाती है, तो आप जेएस डोम तरीकों और गुणों का उपयोग करके किसी भी एक्सएमएल तत्व तक पहुंच सकते हैं। हम इस तरह के रूप में डोम गुण का इस्तेमाल किया है childNodes , nodeValue और इस तरह के getElementsById (आईडी) के रूप में डोम तरीकों, getElementsByTagName (tags_name)।

क्रियान्वयन

इस फ़ाइल को loadingexample.html के रूप में सहेजें और इसे अपने ब्राउज़र में खोलें। आपको निम्न आउटपुट प्राप्त होंगे -

XML स्ट्रिंग के रूप में सामग्री

निम्न उदाहरण दर्शाता है कि XML सामग्री XML फ़ाइल के रूप में प्राप्त होने पर Ajax और जावास्क्रिप्ट का उपयोग करके XML डेटा को कैसे लोड किया जाए। यहाँ, Ajax फ़ंक्शन, एक xml फ़ाइल की सामग्री प्राप्त करता है और इसे XML DOM में संग्रहीत करता है। एक बार DOM ऑब्जेक्ट बन जाने के बाद इसे पार्स किया जाता है।

<!DOCTYPE html>
<html>
   <head>
      <script>
         
         // loads the xml string in a dom object
         function loadXMLString(t) { // for non IE browsers
            if (window.DOMParser) {
               // create an instance for xml dom object parser = new DOMParser();
               xmlDoc = parser.parseFromString(t,"text/xml");
            }
            // code for IE
            else { // create an instance for xml dom object
               xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
               xmlDoc.async = false;
               xmlDoc.loadXML(t);
            }
            return xmlDoc;
         }
      </script>
   </head>
   <body>
      <script>
         
         // a variable with the string
            var text = "<Employee>";
            text = text+"<FirstName>Tanmay</FirstName>";
            text = text+"<LastName>Patil</LastName>";
            text = text+"<ContactNo>1234567890</ContactNo>";
            text = text+"<Email>[email protected]</Email>";
            text = text+"</Employee>";

         // calls the loadXMLString() with "text" function and store the xml dom in a variable
            var xmlDoc = loadXMLString(text);
	
         //parsing the DOM object
            y = xmlDoc.documentElement.childNodes;
            for (i = 0;i<y.length;i++) {
               document.write(y[i].childNodes[0].nodeValue);
               document.write("<br>");
            }
      </script>
   </body>
</html>

कोड का अधिकांश विवरण स्क्रिप्ट कोड में होता है।

  • एक्सएमएल डेटा को एक डोम ऑब्जेक्ट में लोड करने के लिए इंटरनेट एक्सप्लोरर ActiveXObject ("Microsoft.XMLDOM") का उपयोग करता है, अन्य ब्राउज़र DOMParser () फ़ंक्शन और parseFromString (पाठ, 'पाठ / xml') विधि का उपयोग करते हैं।

  • चर पाठ में XML सामग्री के साथ एक स्ट्रिंग होगी।

  • एक बार XML सामग्री जावास्क्रिप्ट एक्सएमएल डोम में बदल जाती है, तो आप जेएस डोम के तरीकों और गुणों का उपयोग करके किसी भी एक्सएमएल तत्व तक पहुंच सकते हैं। हमने चाइल्डनोड्स , नोडवैल्यू जैसे डोम गुण का उपयोग किया है ।

क्रियान्वयन

इस फ़ाइल को loadingexample.html के रूप में सहेजें और इसे अपने ब्राउज़र में खोलें। आप निम्न आउटपुट देखेंगे -

अब जब हमने देखा कि XML सामग्री जावास्क्रिप्ट XML DOM में कैसे बदल जाती है, तो अब आप XML DOM तरीकों का उपयोग करके किसी भी XML तत्व तक पहुँच सकते हैं।