I had used XmlHttp in my javascripts for quite long and extensively. espically dealing with grid control... but lately I come to know that it was called as an AJAX... which has much more than that... to make your UI richer. A common way of calling ajax function is to create an object of XMLHttpRequest. this you can either use it directly or can use wrapper libraries available in the market like extjs, JQuery, Prototype etc. to begin with I will present the internal coding of actual ajax code how it works. please see the following code...
Basic Code: First to check which browser we are using and accordingly activate XmlHttp object as
Please note the following things when calling open,
- Always set Async to true.
- always set call back function before calling send()
- To send form data/POST use endcodeURI() for all data values and set mime type of request to "application/x-www-form-urlencoded"
basic advantage of using javascript to post the request to server is that we don't have to wait till server response arrives. instead we can perform other task. I am listing below the XMLHttpRequest objects method available here.
Method/ Property | Description. |
abort() | stops listining for current response. |
getAllResponseHeader() | Get array of response header as key value pair. |
getRespoonseHeader(name) | Get response header by name passed as key. |
open(method, url[,asyncFlag[, "username"[, "password"]]]) | This prepares the xmlHTTPRequest object to make call to the server. |
send(content) | perform http request. |
setRequestHeader(header, value) | Add header to Http requset, normally a key value pair and mostly used to set content type of request. |
onreadystatechange | used to set as callback fucntion that handles request state change.(similar to onclick, onload) |
readyState | returns the status of the request which can be on of following at a time |
responseText | returns server response as String |
ResponseXML | returns server response as XML Document |
status | returns HTTP status code like 200 for OK etc |
statusText | return String representation of HTTP status code like OK for 200, not found for 404 etc. |
In above example I have already shown how I am getting HTML response from server which I am setting back to perticlular html object. see below the example of parsing xml response received from server and setting to html object.
here I assume that I am getting some key-value pair from server as xml response which i need to set to combobox in html so I am passing combobox object to method
xmlHttp.onreadystatechange=usrfunc;
....
....
function processListXML(xmlId, objlist ){
// first remove all existing option values from list box
for(i=objlist.options.length-1;i>=0;i—){
objlist.remove(i);
}
var t = document.getElementById(xmlId);
var tableData = t.getElementsByTagName("RList");
if(tableData != null){
var t = tableData.item(0);
var columns = t.getElementsByTagName("ROption");
if(columns != null){
for (j = 0; j < columns.length; j++){
key= columns[j].getAttribute("id");
value= columns[j].firstChild.data;
objlist.add(new Option( value ,key ));
}
}
}
}
Now assume that I get following xml
<RList>
<ROption id="01">INDIA </ROption>
<ROption id="02">JAPAN </ROption>
<ROption id="03">AMERICA </ROption>
</RList>