Tuesday, September 7, 2010

AJAX Web application Model


To produce higher performance, more interactive, more efficient Web applications—precisely what the AJAX application model does. In the AJAX model:

  1. "Partial screen update" replaces the "click, wait, and refresh" user interaction model. During user interaction within an AJAX-based application, only user interface elements that contain new information are updated; the rest of the user interface remains displayed without interruption. This "partial screen update" interaction model not only enables continuous operation context, but also makes non-linear workflow possible.
 
  2. Asynchronous communication replaces "synchronous request/response model." For an AJAX-based application, the request/response can be asynchronous, decoupling user interaction from server interaction. As a result, the user can continue to use the application while the client program requests information from the server in the background. When new information arrives, only the related user interface portion is updated.

AJAX uses Http Requests

  In traditional JavaScript coding, if you want to get any information from a database or a file on the server, or send user information to a server, you will have to make an HTML form and GET or POST data to the server. The user will have to click the "Submit" button to send/get the information, wait for the server to respond, then a new page will load with the results.

 Because the server returns a new page each time the user submits input, traditional web applications can run slowly and tend to be less user-friendly.
 With AJAX, your JavaScript communicates directly with the server, through the JavaScript

XMLHttpRequest object

  With an HTTP request, a web page can make a request to, and get a response from a web server - without reloading the page. The user will stay on the same page, and he or she will not notice that scripts request pages, or send data to a server in the background.
AJAX Browser Support

  By using the XMLHttpRequest object, a web developer can update a page with data from the server after the page has loaded!
  AJAX was made popular in 2005 by Google (with Google Suggest).
  Google Suggest is using the XMLHttpRequest object to create a very dynamic web interface: When you start typing in Google's search box, a JavaScript sends the letters off to a server and the server returns a list of suggestions.
 The XMLHttpRequest object is supported in Internet Explorer 5.0+, Safari 1.2, Mozilla 1.0 / Firefox, Opera 8+, and Netscape 7.
AJAX – The XMLHttpRequest Object

The keystone of AJAX is the XMLHttpRequest object.
Different browsers use different methods to create the XMLHttpRequest object.
Internet Explorer uses an ActiveXObject, while other browsers uses the built-in JavaScript object called XMLHttpRequest.

AJAX - The XMLHttpRequest Object

How to get hold of XMLHTTPRequest object?

<html>
<body>
<script type="text/javascript">
function getHTTPObject()
{
var xmlhttp;
if (window.XMLHttpRequest)        // Firefox, Opera 8.0+, Safari
{
xmlhttp = new XMLHttpRequest();
}
else if (window.ActiveXObject)     // Internet Explorer
{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlhttp;
}
</script>
</body></html>

Four important properties of the XMLHttpRequest object:

•        onreadystatechange Property

  After a request to the server, we need a function that can receive the data that is returned by the server.

  The onreadystatechange property stores the function that will process the response from a server. The following code defines an empty function and sets the onreadystatechange property at the same time:

  xmlHttp.onreadystatechange=function()

  {

        // We are going to write some code here

  }

•        readyState Property

 The readyState property holds the status of the server's response. Each time the readyState changes, the onreadystatechange function will be executed.

  Here are the possible values for the readyState property:

  State        Description
  0                The request is not initialized
  1                The request has been set up
  2                The request has been sent
  3                The request is in process
  4                The request is complete
  xmlHttp.onreadystatechange=function()
  {
    if(xmlHttp.readyState==4)
     {
         // Get the data from the server's response
    }
  }

•        responseText Property

 The data sent back from the server can be retrieved with the responseText property.

  xmlHttp.onreadystatechange=function()

 {
   if(xmlHttp.readyState==4)
   {
            document.myForm.time.value=xmlHttp.responseText;
   }
 }

•        status Property

 The HTTP status code of 200 signifies a successful HTTP interaction.

 xmlHttp.onreadystatechange=function()
 {
   if(xmlHttp.readyState==4)
   {
if (xmlHttp.status == 200)
{
                    document.myForm.time.value=xmlHttp.responseText;
      }
   }
 }

No comments:

Post a Comment