Great Webate - Ajax Not The Future Of The Web

— Paul Annesley, August 2007

Last night was the Melbourne Web Standards Group's first ever Great Webate. I teamed up with Kevin Yank to argue against the proposition That Ajax Is The Future Of The Web, with James Edwards and Andrew Krespanis arguing the affirmative. As the first negative speaker, my argument went something like this...

I'm sorry to be the one to break it to you all, but Ajax is not the future of the web. Now don't get me wrong - I know that people are achieving some great things with Ajax - especially considering all the pitfalls, inconsistencies and security models they need to work around. They're doing great, and building great things. But the future of the web? I don't think so.

The web was designed around a simple page based model, and from this page based model, many more technologies emerged.

This page based model was working well - but then one day someone told us we were only on version 1 of the web, and that we needed a shiny new web version 2.0. (At the time we thought shiny was just a figure of speech.)

With Web 2.0 came Ajax, and a new class of applications which provided a rich and responsive user experience by communicating with the server in the background, and making live updates to the page. These "Connected Applications" are far more responsive and interactive than traditional web pages, and this is certainly a great thing.

But as the technology grows up, we'll find that these Connected Apps are a square peg, and the web browser is a round hole. This is why the big players like Adobe, Sun and Microsoft are investing in technology like AIR, Java Web Start and XAML to bring connected applications out of the browser, and away from the hacks and clunky security model of Ajax.

Ajax has been a great here-and-now prototype for connected applications, but it is not the future of the web.

Stay tuned for a recap of my argument against the third debate proposition of the night, That Tables Still Have A Place In Web Page Layout...

← index