| By Coach Wei | Article Rating: |
|
| March 18, 2007 02:00 PM EDT | Reads: |
28,807 |
The Code
The AjaxWord client consists of
JavaScript and HMTL code. The application's user interface is defined
in HTML. Client-side logic written in JavaScript defines the behavior
of the user interface by leveraging a generic JavaScript/DHTML toolkit
that's built from scratch. From a Model-View-Controller perspective,
the HTML files are "Views" and the JavaScript code acts as
"Controllers."
The JavaScript/DHTML toolkit defines all the UI widgets. By separating UI widgets from the application, it's easier to develop and maintain the application code. Because of the level of richness required by AjaxWord and the limited availability of AJAX toolkits in the late 1990s, this entire toolkit was written from scratch. It would have been easier to build AjaxWord today by leveraging some of the available toolkits that have emerged in the last 12 months.
A Generic DHTML/JavaScript Toolkit
The AjaxWord
DHTML/JavaScript toolkit is a generic toolkit that contains a list of
rich user interface components, event management, and code for doing
asynchronous communications.
In Figure 10, the left items are available with Web browsers. All other items aren't available in browsers and have to be built from scratch. In addition to UI elements, the toolkit provides a systematic way of managing UI events and doing asynchronous communications. When the application was written, the popular XmlHttpRequest object wasn't available in browsers, so AjaxWord actually uses hidden frames to asynchronously communicate.
Instead of elaborating on how each component is built, we will use the "window" object as an example. The window object that we are referring to is a draggable, resizable window that resides inside a standard browser window, giving the look-and-feel of a multiple document interface. It is a basic component for desktop application user interfaces, but isn't available for Web applications.
Creating a "Window" Widget
Figure 11
shows how an AjaxWord UI Toolkit window is running inside a browser
alongside some HTML text. We'll explain how to define its view and its
behavior below.
Defining the View
The view is defined using HTML.
To mimic a window look, the view defines 14 different areas of a
"window" user interface: the four corners, the four edges, the window
content, the title bar, and the four window control areas (close,
maximize, minimize, and the window icon). Figure 12 shows how a window user interface is split into 14 different regions.
Each window area is defined by a "DIV" tag. For the four corners and four edges, each DIV tag contains an image. Each of the four window controls also contain an image. When necessary, these images can be changed according to style requirements. Some of DIV tags have event handlers defined too so that the window can respond to events. The view definition code is shown in Listing 1.
Defining the Controller
The controller logic of a
window widget is defined using JavaScript. The JavaScript file
"NWindow.js" is one of the controllers that define the basic behavior
of a window widget.
Window Initialization
When a window is
created, "NWindow.js" initializes it by connecting the JavaScript
object with the "view" object (HTML code), hooking up event handlers
and initializing object properties. See Listing 2 for the initialization code.
Window Event Handling
The JavaScript file
handles various window-related events such as resizing the window in
response to mouse-drag events on the four edges, maximizing the window
or closing the window in response to mouse-click events, or moving the
window in response to mouse-drag events on the title bar. On the other
side, the JavaScript file also fires window events to the toolkit's
event management system so that if a listener is registered for a
certain window event, the listener can be called.
Window Widget API
The JavaScript file
also provides an API for developers to program this window object, such
as setting the window title or resizing the window programmatically.
The code in Listing 3 lets developers set the title, status, and icon of a window object
AjaxWord Client Application Logic
AjaxWord does a
significant amount of processing on the client side for application
performance reasons. With a lot of code on the client side,
applications can deliver better performance. However, such applications
must be designed and coded carefully to avoid code maintenance problems.
The abstraction of UI widgets into a generic AJAX toolkit certainly helps code maintenance. AjaxWord also uses an object-oriented, event-driven approach to develop the application's client-side logic to manage and maintain the client-side code.
All client-side logic resides in two JavaScript files: nwWord.js and nwWordMenuListener.js. The first JavaScript file defines the application-wide logic while the second one responds to menu and toolbar events.
Loading the Application
For applications that have
a significant amount of code on the client side, developers have to
consider how the application is being loaded. Otherwise users will
think the application is slow and abandon it.
AjaxWord requires a significant amount of initial download (several hundred kilobytes, dozens of HTML and JavaScript files, and many image files). This download process can take anywhere from a few seconds on a fast connection to 40 seconds on a slow dialup connection. To engage the user and improve perceived performance, AjaxWord uses a progress bar to indicate the loading progress so that the user knows the status and gets constant visual feedback, as shown in Figure 13
AjaxWord uses the code snippet below to update the progress bar and the status message. This code snippet follows each JavaScript file declaration statement so the "loadProgress1()" method will be executed every time a new file finishes loading:
<SCRIPT TYPE="text/JavaScript">loadProgress1();</script>
This way the user sees the progress being made as the application loads. Listing 4 is the loading page for AjaxWord.
Published March 18, 2007 Reads 28,807
Copyright © 2007 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
More Stories By Coach Wei
Coach Wei is the Founder and Chairman of Nexaweb (www.nexaweb.com), developers of the leading software platform for building and deploying Web 2.0 and AJAX applications. Previously, he played a key role at EMC Corporation in the development of a new generation of storage network management software. Wei has his master's degree from MIT, holds several patents, is the author of several technology publications including JDJ, Web 2.0 Journal, and AJAXWorld Magazine, and is an industry advocate for the proliferation of open standards.
![]() |
bijalvp 10/07/09 03:08:00 AM EDT | |||
Great post. Thank you for sharing about what seems to be a great platform. Your website www.ajaxword.com is not accessible however so cannot get to the source code. Can you kindly tell me how to access this information and/or website? Thanks again. Bijal |
||||
![]() |
arun_in_1980 11/01/08 05:09:44 AM EDT | |||
Hi Please look into the matter and please give me some other link or other source to get source code of this application. Given the listings of code at http://ajax.sys-con.com/node/345840 are not appropriate as they only give the technical overview of the application. So please provide me the full source code so that i can take advantage of it. Regards |
||||
- Kindle 2 vs Nook
- Cloud Computing on Gartner's Top 10 List and SYS-CON Events' 2010 Calendar
- Confessions of a Ulitzer Addict
- IBM Hardware Chief, Intel VC Exec Arrested in Insider Trading Scam
- Tactical Cloud Computing Panel at 1st Annual GovIT Expo
- Ulitzer.com Named Exclusive "New Media" Sponsor of Cloud Computing Conference & Expo
- Moving Your RIA Apps into the Cloud: Seven Challenges
- Adobe’s Aiming ColdFusion at Multiple Clouds
- Windows 7 – Microsoft’s First Step to the Cloud
- Ulitzer Provides a Powerful Social Journalism Platform
- Jill Tummler Singer, Deputy CIO of CIA, Keynotes at GovIT Expo
- Open Source Mobile Cloud Sync and Push Email
- Kindle 2 vs Nook
- The Difference Between Web Hosting and Cloud Computing
- Cloud Computing on Gartner's Top 10 List and SYS-CON Events' 2010 Calendar
- Ajax in RichFaces 3.3, JSF 2 and RichFaces 4
- Confessions of a Ulitzer Addict
- IBM Hardware Chief, Intel VC Exec Arrested in Insider Trading Scam
- My Thoughts on Ulitzer
- Tactical Cloud Computing Panel at 1st Annual GovIT Expo
- Ulitzer.com Named Exclusive "New Media" Sponsor of Cloud Computing Conference & Expo
- US Post Office Hops a Ride on NetSuite’s Cloud
- Moving Your RIA Apps into the Cloud: Seven Challenges
- Adobe’s Aiming ColdFusion at Multiple Clouds
- Building a Drag-and-Drop Shopping Cart with AJAX
- What Is AJAX?
- Google Maps! AJAX-Style Web Development Using ASP.NET
- Flashback to January 2006: Exclusive SYS-CON.TV Interviews on "OpenAjax Alliance" Announcement
- AJAXWorld Conference & Expo to Take Place October 2-4, 2006, at the Santa Clara Convention Center, California
- AJAX Sponsor Webcasts Are Now Available at AJAXWorld Website
- How and Why AJAX, Not Java, Became the Favored Technology for Rich Internet Applications
- "Real-World AJAX" One-Day Seminar Arrives in Silicon Valley
- AJAXWorld University Announces AJAX Developer Bootcamp
- AJAX Support In JadeLiquid WebRenderer v3.1
- Where Are RIA Technologies Headed in 2008?
- Struts Validations Framework Using AJAX



































