XML DOM - Memuat

Pada bab ini, kita akan mempelajari tentang XML Loading dan Parsing .

Untuk menggambarkan antarmuka yang disediakan oleh API, W3C menggunakan bahasa abstrak yang disebut Bahasa Definisi Antarmuka (IDL). Keuntungan menggunakan IDL adalah pengembang belajar bagaimana menggunakan DOM dengan bahasa favoritnya dan dapat dengan mudah beralih ke bahasa lain.

Kerugiannya adalah, karena abstrak, IDL tidak dapat digunakan secara langsung oleh pengembang Web. Karena perbedaan antara bahasa pemrograman, mereka perlu memiliki pemetaan - atau pengikatan - antara antarmuka abstrak dan bahasa konkretnya. DOM telah dipetakan ke bahasa pemrograman seperti Javascript, JScript, Java, C, C ++, PLSQL, Python, dan Perl.

Pada bagian dan bab berikut, kami akan menggunakan Javascript sebagai bahasa pemrograman kami untuk memuat file XML.

Parser

Sebuah parser adalah aplikasi perangkat lunak yang dirancang untuk menganalisis dokumen, dalam dokumen XML kasus kami dan melakukan sesuatu yang spesifik dengan informasi. Beberapa parser berbasis DOM tercantum di tabel berikut -

S.No Parser & Deskripsi
1

JAXP

Java API Sun Microsystem untuk XML Parsing (JAXP)

2

XML4J

Parser XML IBM untuk Java (XML4J)

3

msxml

Microsoft XML parser (msxml) versi 2.0 sudah terpasang di Internet Explorer 5.5

4

4DOM

4DOM adalah parser untuk bahasa pemrograman Python

5

XML::DOM

XML :: DOM adalah modul Perl untuk memanipulasi dokumen XML menggunakan Perl

6

Xerces

Xerces Java Parser dari Apache

Dalam API berbasis pohon seperti DOM, parser melintasi file XML dan membuat objek DOM yang sesuai. Kemudian Anda dapat melintasi struktur DOM bolak-balik.

Memuat dan Mengurai XML

Saat memuat dokumen XML, konten XML bisa datang dalam dua bentuk -

  • Langsung sebagai file XML
  • Sebagai string XML

Konten sebagai file XML

Contoh berikut menunjukkan cara memuat data XML ( node.xml ) menggunakan Ajax dan Javascript saat konten XML diterima sebagai file XML. Di sini, fungsi Ajax mendapatkan konten file xml dan menyimpannya di XML DOM. Setelah objek DOM dibuat, objek tersebut kemudian diurai.

<!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>

Sebagian besar detail kode ada di kode skrip.

  • Internet Explorer menggunakan ActiveXObject ("Microsoft.XMLHTTP") untuk membuat instance objek XMLHttpRequest, browser lain menggunakan metode XMLHttpRequest () .

  • yang responseXML mengubah konten XML langsung dalam DOM XML.

  • Setelah konten XML diubah menjadi JavaScript XML DOM, Anda dapat mengakses elemen XML apa pun dengan menggunakan metode dan properti JS DOM. Kami telah menggunakan properti DOM seperti childNodes , nodeValue dan metode DOM seperti getElementsById (ID), getElementsByTagName (tags_name).

Eksekusi

Simpan file ini sebagai loadingexample.html dan buka di browser Anda. Anda akan menerima output berikut -

Konten sebagai string XML

Contoh berikut menunjukkan cara memuat data XML menggunakan Ajax dan Javascript saat konten XML diterima sebagai file XML. Di sini, fungsi Ajax, mendapatkan konten file xml dan menyimpannya di XML DOM. Setelah objek DOM dibuat, objek tersebut kemudian diurai.

<!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>

Sebagian besar detail kode ada di kode skrip.

  • Internet Explorer menggunakan ActiveXObject ("Microsoft.XMLDOM") untuk memuat data XML ke dalam objek DOM, browser lain menggunakan fungsi DOMParser () dan metode parseFromString (teks, 'teks / xml') .

  • Teks variabel harus berisi string dengan konten XML.

  • Setelah konten XML diubah menjadi JavaScript XML DOM, Anda dapat mengakses elemen XML apa pun dengan menggunakan metode dan properti JS DOM. Kami telah menggunakan properti DOM seperti childNodes , nodeValue .

Eksekusi

Simpan file ini sebagai loadingexample.html dan buka di browser Anda. Anda akan melihat output berikut -

Sekarang setelah kita melihat bagaimana konten XML berubah menjadi JavaScript XML DOM, Anda sekarang dapat mengakses elemen XML apa pun dengan menggunakan metode XML DOM.