-C-O-N-C-E-P-T- Series : Making simultaneous AJAX calls to the same servlet
AJAX calls are "asynchronous" in nature. So what does this mean? You can have multiple requests to same (or different) servlets with each request processed asynchronously. Right, so are you speaking anything new?? Yes I am :) When you make simultaneous AJAX calls to the same servlet, the last call overlaps the response text with the previous, so as a result you get only the last requet's response text i.e. HTTP requests are overlaped. I faced this this problem in one of our Project, so I thought to share some views on it.
Examples:
Traditional code:
function ajaxRequest() {
...
myRequest.onreadystatechange = callBack; // assign callback function
...
}
function callBack() {
if (myRequest.readyState == 4) {
if (myRequest.status == 200) {
// Update DOM
}
}
}
Rearranging the above code:
Now we make some rearrangement of the AJAX code so that multiple HTTP requests can go on simultaneously. To do this, the XMLHTTP request object must be instantiated inside the Javascript function that calls the server. Furthermore, all code related to the request must be inside this function. The callback function must be an anonymous inner function within the ajaxRequest() function, and the code which updates the page after the callback must also be within the anonymous inner function.
function ajaxRequest() {
...
myRequest.onreadystatechange = function()
{
if (myRequest.readyState == 4)
{
if (myRequest.status == 200)
{
// update DOM with results
}
}
} // end anonymous inner function (callback)
...
}
Doing this I was able to handle multiple AJAX calls simultaneously.
Please feel free to correct me at any point :)
2 comments:
i think the archive you wirte is very good, but i think it will be better if you can say more..hehe,love your blog,,,
It seems my language skills need to be strengthened, because I totally can not read your information, but I think this is a good BLOG
Post a Comment