AJAX
AJAX Custom Error Handling: Enhancing the Interactive User Experience
AJAX and Rich Internet Applications
Mar. 19, 2006 09:15 AM
Now let's say that the connection to the database was down when the user first entered the application. The function in Listing 1 is used to get a list of all the departments in the company.
If the database server is down the cfcatch will catch a database error and throw a new error message that will tell the user that the database server is down, it's up to the page that calls this function to trap the error and set the session.error and session.errorMessage variables:
<cfscript>
try
{
Department = CreateObject("Component","CFDJ.Components.Department");
DepartmentArray = Department.GetAllDepartments(#session.dsn#);
}
catch(Any ex)
{
session.error = true;
session.errorMessage = ex.Message;
}
</cfscript>
In this case the employee update page would look like Figure 4 when the user enters the application.
Next let's look at using JavaScript to do some simple client-side error handling. The first step is to check for invalid data. I'll assume that you've had some experience doing simple JavaScript error checking and skip right to displaying the error. For our example, we're going to have the JavaScript check to make sure that the user has selected the name of a user to edit from the user drop-down. The first step would be to make sure that the selected index of a drop-down is not zero. Typically the next step would be to display some sort of message to the user with the Alert() function. In this case we'll simply call the ShowError() function that we wrote above:
if(departmentSelect.selectedIndex != 0)
{
//do something
}
else
{
ShowMessage('Please select an employee to update',true);
}
Conclusion
Adding a messaging system to an AJAX application isn't a very complicated, but it can be an extremely useful technique for keeping your end users informed. This application can be viewed online at www.innovacreative.com/cfdj/ajax. The source code can be downloaded from www.innovacreative.com/cfdj/ajax/ajax.zip.
About Ryan AnklamRyan Anklam is the Chief Information Officer at Innova Creative Media, Inc. His current focus is on using ColdFusion to develop large scale hosted applications. Ryan has been developing ColdFusion applications since 1996. In addition, he is also a Microsoft Certified Professional with demonstrated skills in C# and SQL Server.
#6 |
Kim commented on 20 Mar 2006
On page two, it reads Creating JavaScript to Handle the Errors
Let's take a look at what we've done so far: we've created our CSS style classes, we've created our display container, we have our query, our template to update the employee record, and created our error-handling logic.
I don't see where we created the query or the template to update the employee record so far in the article.
|
#5 |
Dave commented on 20 Mar 2006
Unfortunately the links to the demo and zip file are not working for this article. Is there another place one can test this out and download the source?
Thanks,
Dave
|
#4 |
SYS-CON India News Desk commented on 19 Mar 2006
AJAX has become an increasingly popular tool to develop RIAs. With AJAX, as with many new technologies, developers often overlook core application issues such as error handling. While many current AJAX frameworks come with ways to handle errors, the built-in error-handling methods might not be quite what you need, and it's possible that you might not even want to adopt a specific AJAX framework at all. So how do you handle errors in AJAX?
|
#3 |
SYS-CON Italy News Desk commented on 19 Mar 2006
AJAX has become an increasingly popular tool to develop RIAs. With AJAX, as with many new technologies, developers often overlook core application issues such as error handling. While many current AJAX frameworks come with ways to handle errors, the built-in error-handling methods might not be quite what you need, and it's possible that you might not even want to adopt a specific AJAX framework at all. So how do you handle errors in AJAX?
|
#2 |
Dev commented on 19 Mar 2006
The URL for download the source cannot be reached. Is there any other way to get the source ?
|
#1 |
Dev commented on 19 Mar 2006
The URL for download the source cannot be reached. Is there any other way to get the source ?
|