AJAX: A Fresh Look at Web Development
Monday 27th of March 2017 08:11:57 PM Couldn't it be nice if you could turn your plain old Web pages into something more exciting? Isn't it time to inject some life into your decade-old Web technologies? If you feel the need for the fresher, richer, and more interactive Web experience, get to know AJAX.

If you use Google Maps or the Gmail Web client you actually have experienced an AJAX-based solution already. AJAX, which stands for asynchronous JavaScript and XML, is a conglomerate technology that enables dynamic, asynchronous behavior on Web pages without the need for annoying browser page refreshes. Utilizing AJAX, users can interact with Web pages almost as they would with rich clients.

AJAX is a simple technology that all the major browsers already support. As you will see shortly, the only prerequisite for AJAX implementation is knowledge of JavaScript.

How AJAX Works

If you've used the Gmail Web client or Google Maps you probably noticed that you can scroll over the map or spell check the typed text, respectively, without page submits. AJAX, the technology behind this behavior, handles the requested operations in _JavaScript and asynchronously invokes the server-side operations that provide the desired results.

Introducing the XMLHttpRequest
At the core of AJAX technology is a JavaScript object: XMLHttpRequest. This object has been supplied through browser implementations—first through Internet Explorer, and then through Mozilla/Safari. At the time of writing this article, version 8 of the Opera browser supplied a compatible implementation. However, Opera has had a somewhat rocky history in terms of the stability of its XMLHttpRequest implementation.

AJAX in Action

In order to demonstrate AJAX, this tutorial implements a common portal scenario: e-mail message previewing. ( for the application source code.) Most Web portals allow portal users to preview the contents of their e-mail inboxes from the main page. In order to view the body text in their messages, however, users need to click on the individual messages—one by one, refreshing the page each time. This case study demonstrates how to practically accomplish richer Web client behavior, similar to what rich clients like Outlook Express and Mozilla Thunderbird provide, utilizing the existing Web technologies of AJAX.

It builds a portlet that provides not only access to the list of most recent messages but also previews of the messages themselves—all from the main page without needing to refresh.

In order to access message content, you need a server component that provides access to the messages. This demonstration utilizes a trivial servlet that will serve as a simulator, providing a comma-separated representation of the messages: from, subject, date, and message body:


@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
if ( req.getParameter( "message_id" ).equals( "1" ) ){
resp.getWriter().println( "John Doe,Greetings,10-10-2005,Hi.I am doing good" );
}else if ( req.getParameter( "message_id" ).equals( "2" ) ){
resp.getWriter().println( "Joanna Doe,Hi,10-10-2005,Document is complete." );
}else if ( req.getParameter( "message_id" ).equals( "3" ) ){
resp.getWriter().println( "Joanna Doe,Hi,10-10-2005,Meeting is at 3." );
...
}else{
resp.getWriter().println( ",NA ,NA ,NA ,Nothing to display" );
}//end else
}//end service

Your portal will have a mail preview portal window/portlet with a simplistic inbox listing on the left side and the preview pane on the right side. As you mouse over the message on the left, the preview pane makes the server call and displays the message text—in real time—utilizing AJAX.



Step 1: Creating Web Mail Preview Portlet
 
Figure 1. Web Page That Simulates a Typical Web Mail Portlet

To begin, create the Web page that simulates the look and feel of a typical Web mail portlet and incorporates JavaScript onMouseOver events that trigger AJAX calls (see Figure 1).

In this case, "onMouseOver" events are attached to table fields (TD) that contain names of the e-mail senders. This choice of data fields and the triggering events for AJAX calls are strictly for illustrative purposes:


<form name="inbox">
<table style="previewTable">
<thead id="tableHeader">
<tr>
<td>From</td>
<td>Subject</td>
</tr>
</thead>
<tbody>
<tr class="even">
<td onMouseOver="displayMessageBody(1)">John Doe</td>
<td>Greetings</td>
</tr>
<tr>
<td onMouseOver="displayMessageBody(2)">Joanna Doe</td>
<td>Status of the report</a></td>
</tr>
<tr class="even">
<td onMouseOver="displayMessageBody(3)">Jim Doe</td>
<td>Meeting is today</td>
</tr>
...
</tbody>
</table>
</div>
<div id="preview">
<input id="messageBody"class="message" type="textarea" READONLY value=""/>
</div>
</form>

Notice that the input field "messageBody" is the one that will be populated by the method displayMessageBody, which takes the message ID as a parameter. An AJAX call will use this parameter to request the message details from the server. (Complete source for this application is available for download. Please see resources)

Step 2: Making an AJAX Call
The key element of this implementation is an AJAX call. In the following code, notice how different browser implementations require different instantiation methods for the XMLHttpRequest object:

function getHTTPRequestObject() {
var xmlHttpRequest;
/*@cc_on
@if (@_jscript_version >= 5)
try {
xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP");
} catch (exception1) {
try {
xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP");
} catch (exception2) {
xmlhttp = false;
}
}
@else
xmlhttpRequest = false;
@end @*/
if (!xmlHttpRequest && typeof XMLHttpRequest != 'undefined') {
try {
xmlHttpRequest = new XMLHttpRequest();
} catch (exception) {
xmlHttpRequest = false;
}
}
return xmlHttpRequest;
}
var httpRequester = getHTTPRequestObject(); // Create the xml http object on the page load
</script>

This code utilizes Internet Explorer annotations to instantiate an AJAX object. Other browsers executing this script will simply ignore the annotated sections of the getHTTPRequestObject() function. Keep in mind that your browser must support JavaScript 1.5 and above.



Step 3: Asynchronous Loading of the Content
This step implements the asynchronous invocation of the Web resources. The following code illustrates the exact steps required for the asynchronous loading of the Web resources from the JavaScript function:

var couldProcess = false;
function displayMessageBody( messageID ) {
idToDisplay = messageID
if (!couldProcess && httpRequester) {
httpRequester.open("POST", serverSideURL + escape(messageID), true);
httpRequester.onreadystatechange = processResponse;
couldProcess = true;
httpRequester.send(null);
}
}

The method displayMessageBody accepts the ID of the message to display. It specifies how the XMLHttpRequest object should access the URL by passing the following three parameters:

  • The method POST or GET
  • The URL, plus any escaped parameters (In this case, you pass only an ID. To specify multi-parameter URLs, use the standard URL query string notations and always escape.)
  • A Boolean flag indicating whether the call should be executed in an asynchronous fashion

The method also sets the content-processing method processResponse as a callback, which is invoked when the content from the URL loads.

Step 4: Processing the Results
The previously mentioned method processResponse is invoked as a callback. It takes the output from the XMLHttpRequest object, parses it, and assigns it to the page object(s):

function processResponse() {
if ( httpRequester.readyState == COMPLETE ) {//this is a locally declared constant, its
if ( httpRequester.responseText.indexOf('invalid') == -1 ) {
var values = httpRequester.responseText.split(","); // parse the server response
document.getElementById('messageBody').value = values[3];//pick the fourth value
couldProcess = false;
}
}
}

HttpRequester.readyState is an indicator that declares the completion of the URL code. It can take the following values:

  • 0 = uninitialized
  • 1 = loading
  • 2 = loaded
  • 3 = interactive
  • 4 = complete (This demo focuses on this state.)
  • Notice that the response is accessed as textual content. XMLHttpRequest can easily retrieve non-XML text, as well as XML content.

    If you needed to retrieve XML content, the line would read responseXML and you would access it as XML DOM object. This versatility of text formats is welcome news because XML could be overkill for simple data retrieval scenarios like the one described here.



    Step 5: Improving the Robustness of the AJAX Application
    Any extensive use of JavaScript inevitably raises concerns about the robustness and reliability of an application that heavily relies on this very relaxed and forgiving scripting language. With AJAX, the issue is even more complicated. AJAX makes remote calls, which introduce an additional dimension of complexity and the opportunity for errors—especially considering that built-in support for server-side error conditions is very limited.

    With all this in mind, here are some immediate error-prevention suggestions:

    • Make sure that your application can function in a bare bones mode, even without the AJAX.
    • Verify response codes from the AJAX calls before the further processing of the results.XMLHttpRequest API supports HTTP codes (200, 400, ...). These can be accessed via the status property (along with the statusText property, which holds the message associated with the status of the response):
      
      if ( httpRequester.readyState == 4) {
      if ( httpRequester.status == 200) {
      } else {
      }
      

    AJAX Implementation: An Art of Tradeoffs

    Many programmers consider JavaScript a sub-optimal programming solution because of its lacking debugging methods and its error-prone, weak-typed programming model. With this in mind, it is fair to say that AJAX is a solution of trade-offs. You trade the safety of the more robust languages like Java There are many different types of software that you can write in Java to make use of XML. I have created 3 major categories to describe certain types of apps (that are currently popular) that are really well suited to the use of XML. This is by no means a comprehensive set of categories; you can create your own, and many more major categories will emerge as XML becomes more popular.

    Client side - Graphical Java Applications

    The simplest category of XML Java applications is the kind of Java application that stores information in XML documents (files). This is illustrated in Figure 1. By using XML to create your own markup languages (i.e. your own file formats for your information) in an open way, you don't have to use propietary and binary file formats. Using XML over proprietary binary file formats, allows your applications to have immense inter operability across platforms, applications and even programming languages. Since any kind of markup language can be defined using XML (you can even formalize it by creating a DTD for it) applications can store their information using their own markup languages. For example, address book information can be stored in an AddressBookML file. A few commercial programs currently available allow saving their application data to XML files, e.g., Framemaker can save its documents as XML files.

    or C# for the presentational attractiveness and the innovative appeal of this JavaScript-based technology.

    Hopefully, the popularity of AJAX and the increasing use of JavaScript will prompt browser producers to further innovate the JavaScript objects and incorporate mechanisms that make JavaScript objects a bit more compatible, safer to use, and easier to debug.

    In the meantime, I see AJAX as an immediate candidate for the new generation of Internet portals and interactive applications. With AJAX, Internet news portals such as Yahoo, Google News, or MSN will allow users to access all areas of interest—including specific details—from the same portal page.

    The promise of rich clients that can be implemented by leveraging existing Web technologies and Internet infrastructure as-is is attractive. Interactive communication applications already have adopted AJAX—Google uses it for its ultra-popular Gmail e-mail client—and I expect this trend to continue.

    One advantage that software development teams will enjoy is this technology's accessibility and flat learning curve. As previously mentioned, it is available on all modern browsers. Also, it does not require advanced programming skills like J2EE or .NET, yet it can produce impressive and effective results that will appeal to end users.

    P {line-height: 18pt;}H2 {line-height: 200%;}
    list-styleIE4 P/P IE5 Y/Y NN4 P/P Op3 Y/-

    A shorthand property condensing allother list-style properties. It applies to allelements with a display value of list-item ; inordinary HTML, this is any <LI> element.

    Example

    UL {list-style: square url(bullet3.gif) outer;}  /* values are inherited by LI elements */
    declare an image which is to be used as the "bullet" in the CSS1 specification,required to fully support negative margins, using the phrase,"A negative value is allowed, but there may beimplementation-specific limits." In the world of web browsers,though Navigator 4.x, Explorer 4.x/5.x, and Opera 3.x do permitnegative margins:

    Negative margins have an impact on vertical formatting, affecting howmargins are collapsed. If there are negative vertical margins, thencan probably guess that they set H1 elements to be maroon and BODY elements to have a yellow background.

    Styles such as these comprise the bulk of any embedded style sheet -- style rules both simple and complex, short and long. It will be only rarely that you have a document where the STYLE element does not contain any rules.

    line.

    Figure 7-19

    Figure 7-19. Negative margin

    Negative percentages are also permitted. These will behave like any negative length value, with the obvious difference that the amount of negativity will depend on the width of the parent element. Thus:

    P {margin: -10%;}

    Figure 7-20 illustrates the consequences of such a rule, where the amount by which paragraphs overlap each other andFor example, if you have images with ALT text offig-1, fig-2,fig-3, and so on, and want to match any of them,you could use this selector:

    IMG[alt|="fig"]

    This is a less likely use for |=, but it'sstill perfectly valid. Note that the previous rule would not matchthe value figure or config, asneither of them starts with fig- or is simply