-
Get a monthly update on best practices for delivering successful software.
The problem with new technologies is that they quickly get misused the same way the old technologies did. Case in point: this discussion of Ajax in an article from Internet Retailer titled Web 2.0 tools improve shoppers’ experience, sales, experts say (emphasis mine):
Web 2.0 technology enables customers to get more product information and interact with e-retailers, says David Fry, president, Fry Inc., an e-commerce development and services provider. Key features include customer ratings, user-generated content and even customer photos showing how they use a product, Fry says.
Ajax design tools enable such features. "We think Ajax is the most important technology to be using now," Fry says.
This kind of boosterism may help generate revenue for web shops by making the target audience (business and product folks at small and mid-sized eCommerce sites) afraid of falling behind the times. But it's also short-sighted. Ajax shouldn't be an end in and of itself. It should be a means to an end: making the user experience richer, the application faster and easier to use, or the product more compelling. If Ajax features aren't backed by intelligent UxD, then they're just high-tech wallpaper.
Just look at Flash circa 2000. So many useless bells and whistles. So many slow-loading, low-value splash screens with oh-so-enticing "skip intro" links. So many pointlessly animated navbars with silly transitions slowing down every interaction. It took years - and the maturation of ActionScript - for Flash to lose the stench of its early overuse and misuse. When effects libraries and Ajax interactions get thrown onto sites with the same reckless abandon as .swf files did at the height of the dot-com bubble, it just gets easier to argue that "Web 2.0" is an overheated marketing term.
Over at Bank of America's online banking application, they're really trying to get with the times. When you type in your password and press the submit button, a little message pops up:
Your request is being processed. Please wait.
Cutting-edge, right? Of course, the message is in red, making it appear to most users that they've made an error. There's no visual transition to signal that an event has taken place. Presumably this little enhancement was made to reduce the number of users who spawn multiple requests by repeatedly submitting the form. Yet the submit button itself doesn't disappear. So what's been gained other than the magical appearance of a confusing message - especially when the application on the other side of this login screen benefits from no RIA functionality?
This example is pretty insignificant, but it's indicative of the silly uses to which Ajax (or just plain DHTML) can be put. Another example comes from a previous job of mine at which my team developed a pretty sweet JavaScript library for the management of modal content. Once the product-development folks got a look at the demo, "lightbox" and "microcontent" were the buzzwords for months afterwards. Every new screen had to feature either a little popup bubble full of additional information or a full-screen overlay with scads of content. Never mind whether cramming these new interactions into the same old screens made any sense to the users - or contributed additional click-throughs and purchases.
So how _does_ a small or medium-sized site without a huge app-dev team of its own get some of that Ajax magic? I think a good first step is to treat Ajax as high-teck spackle. Apply it to the holes in your Web 1.0 user interface and you'll provide some real value without having to re-architect from the ground up.
However you choose to dip your toes into the Web 2.0 waters, just remember: Save flashy effects libraries for when you're ready to provide a true RIA experience. Sure, some cool script.aculo.us transitions _seem_ like an easy way to jump on the bandwagon, but if you employ them for their own sake, without a strong grasp of how and when they're useful, then you might as well replace your homepage with a gigantic Flash animation. Just remember to provide that "skip intro" link.
Related posts: