XML DOM Tutorial on DOM XMLHttpRequest Object

xmlhttprequest object establishes a medium between a web page's client-side and server-side that can be used by the many scripting languages like javascript, jscript, vbscript and other web browser to transfer and manipulate the xml data.

with the xmlhttprequest object it is possible to update the part of a web page without reloading the whole page, request and receive the data from a server after the page has been loaded and send the data to the server.

syntax

an xmlhttprequest object can be instatiated as follows −

xmlhttp = new xmlhttprequest();

to handle all browsers, including ie5 and ie6, check if the browser supports the xmlhttprequest object as below −

if(window.xmlhttprequest) // for firefox, ie7+, opera, safari, ... {
   xmlhttp = new xmlhttprequest();
} else if(window.activexobject) // for internet explorer 5 or 6 {
   xmlhttp = new activexobject("microsoft.xmlhttp");
}

examples to load an xml file using the xmlhttprequest object can be referred here

methods

the following table lists the methods of the xmlhttprequest object −

s.no. method & description
1

abort()

terminates the current request made.

2

getallresponseheaders()

returns all the response headers as a string, or null if no response has been received.

3

getresponseheader()

returns the string containing the text of the specified header, or null if either the response has not yet been received or the header doesn't exist in the response.

4

open(method,url,async,uname,pswd)

it is used in conjugation with the send method to send the request to the server. the open method specifies the following parameters −

  • method − specifies the type of request i.e. get or post.

  • url − it is the location of the file.

  • async − indicates how the request should be handled. it is boolean value. where,

    • 'true' means the request is processed asynchronously without waiting for a http response.

    • 'false' means the request is processed synchronously after receiving the http response.

  • uname − is the username.

  • pswd − is the password.

5

send(string)

it is used to send the request working in conjugation with the open method.

6

setrequestheader()

header contains the label/value pair to which the request is sent.

attributes

the following table lists the attributes of the xmlhttprequest object −

s.no. attribute & description
1

onreadystatechange

it is an event based property which is set on at every state change.

2

readystate

this describes the present state of the xmlhttprequest object. there are five possible states of the readystate property −

  • readystate = 0 − means request is yet to initialize.

  • readystate = 1 − request is set.

  • readystate = 2 − request is sent.

  • readystate = 3 − request is processing.

  • readystate = 4 − request is completed.

3

responsetext

this property is used when the response from the server is a text file.

4

responsexml

this property is used when the response from the server is an xml file.

5

status

gives the status of the http request object as a number. for example, "404" or "200".
6

statustext

gives the status of the http request object as a string. for example, "not found" or "ok".

examples

node.xml contents are as below −

<?xml version = "1.0"?>
<company>
   <employee category = "technical">
      <firstname>tanmay</firstname>
      <lastname>patil</lastname>
      <contactno>1234567890</contactno>
      <email>tanmaypatil@xyz.com</email>
   </employee>
   
   <employee category = "non-technical">
      <firstname>taniya</firstname>
      <lastname>mishra</lastname>
      <contactno>1234667898</contactno>
      <email>taniyamishra@xyz.com</email>
   </employee>
   
   <employee category = "management">
      <firstname>tanisha</firstname>
      <lastname>sharma</lastname>
      <contactno>1234562350</contactno>
      <email>tanishasharma@xyz.com</email>
   </employee>
</company>

retrieve specific information of a resource file

following example demonstrates how to retrive specific information of a resource file using the method getresponseheader() and the property readstate.

<!doctype html>
<html>
   <head>
      <meta http-equiv = "content-type" content = "text/html; charset = iso-8859-2" />
         <script>
            function loadxmldoc() {
               var xmlhttp = null;
               if(window.xmlhttprequest) // for firefox, ie7+, opera, safari, ... {
                  xmlhttp = new xmlhttprequest();
               }
               else if(window.activexobject) // for internet explorer 5 or 6 {
                  xmlhttp = new activexobject("microsoft.xmlhttp");
               }

               return xmlhttp;
            }

            function makerequest(serverpage, mydiv) {
               var request =  loadxmldoc();
               request.open("get", serverpage);
               request.send(null);

               request.onreadystatechange = function() {
                  if (request.readystate == 4) {
                     document.getelementbyid(mydiv).innerhtml = request.getresponseheader("content-length");
                  }
               }
            }
      </script>
   </head>
   <body>
      <button type = "button" onclick="makerequest('/dom/node.xml', 'id')">click me to get the specific responseheader</button>
      <div id = "id">specific header information is returned.</div>
   </body>
</html>

execution

save this file as elementattribute_removeattributens.htm on the server path (this file and node_ns.xml should be on the same path in your server). we will get the output as shown below −

before removing the attributens: en
after removing the attributens: null

retrieve header infomation of a resource file

following example demonstrates how to retrieve the header information of a resource file, using the method getallresponseheaders() using the property readystate.

<!doctype html>
<html>
   <head>
      <meta http-equiv="content-type" content="text/html; charset=iso-8859-2" />
      <script>
         function loadxmldoc() {
            var xmlhttp = null;

            if(window.xmlhttprequest) // for firefox, ie7+, opera, safari, ... {
               xmlhttp = new xmlhttprequest();
            } else if(window.activexobject) //  for internet explorer 5 or 6 {
               xmlhttp = new activexobject("microsoft.xmlhttp");
            }

            return xmlhttp;
         }

         function makerequest(serverpage, mydiv) {
            var request =  loadxmldoc();
            request.open("get", serverpage);
            request.send(null);
            request.onreadystatechange = function() {
               if (request.readystate == 4) {
                  document.getelementbyid(mydiv).innerhtml = request.getallresponseheaders();
               }
            }
         }
      </script>
   </head>
   <body>
      <button type = "button" onclick = "makerequest('/dom/node.xml', 'id')">
         click me to load the allresponseheaders</button>
      <div id = "id"></div>
   </body>
</html>

execution

save this file as http_allheader.html on the server path (this file and node.xml should be on the same path in your server). we will get the output as shown below (depends on the browser) −

date: sat, 27 sep 2014 07:48:07 gmt server: apache last-modified: 
      wed, 03 sep 2014 06:35:30 gmt etag: "464bf9-2af-50223713b8a60" accept-ranges: bytes vary: accept-encoding,user-agent 
      content-encoding: gzip content-length: 256 content-type: text/xml