Sunday, March 27, 2011

Web Non-Framework

I recently finished a project to produce a web site described with PhotoShop for deployment to a content management system. To force myself to focus on interface design, I chose to limit the server-side facilities used to includes only.


Includes Only
While I had already reached the conclusion intellectually, the exercise reinforced my impression there is seldom a good reason to build HTML in server-side code.


HTTP ↑ JSON ↓
I have now built two small applications that do not include any HTML building or any sort of "application model" on the server side. Other than includes used as needed, at the top of each page is enough server-side code to invoke security checks and retrieve data formatted in JSON that will be used in all cases. Retrieval of anything optional is left to ajax invocations. The applications in question include sending e-mail, file uploading, image manipulation, and reporting with PDF, so they're not just sunny-day tests.


Tools
On the client side, I have tools to exchange data among JSON objects, form elements and ajax request parameters, and a facility for presenting error messages from client-side validations. On the server side, I have a persistence kit, a flexible model to map requests to data dispensers and updaters and a tool to deliver messages from server-side validations.


Sample


//I really can't imagine that anyone in my intended audience doesn't already know
//exactly how to code everything I've described, so why bother with a sample?

(Preliminary?) Conclusion
As long as the client-side script is kept in good order, I can't yet see where this approach will break down, while I can definitely say that working with this non-framework feels more enjoyable than with any web framework I've used so far.

5 comments:

  1. I've been thinking about this approach for a while as well (although I haven't implemented it yet)

    Another benefit is that you only have to implement things once. For example, if you're populating form fields in server side code, then you add ajax functionality, you may need to repopulate those controls in the client as well ... hence redoing the exact same thing. Validation is another example where you might duplicate the code.

    ReplyDelete
  2. Yeah, if i wasn't still leery of node.js and others like it, it could ~all~ be javascript. (i may still be a little afraid of javascript itself)

    ReplyDelete
  3. I like the line of thought. In my opinion, server-side HTML generation schemes have tended to pull too many varied concerns into one spot.

    Recently, I've been using jQuery templates, which are not a bad way to get JSON into the DOM (not sure I really like the HTML template stuff in script tags though). "Knockout" (knockoutjs.com) appears to have an interesting approach that may be worth a look: an MVVM implementation on the client.

    ReplyDelete
  4. I've been doing something similar on personal projects for a while and been happy with the results. I gave it my own name - "Ajax-Oriented Architecture." I focus on making RESTful (as much as possible) Web services and let the JavaScript handle incorporating it into pages. I have them return either an HTML fragments (for quick and simple) or JSON data (for powerful/flexible) based on Accept header.

    ReplyDelete
  5. I didn't set out to convince anyone of anything, only to point out that there's
    an elegant approach using stuff we do all the time with practically no dependencies
    or apparent limitations.

    I called it a
    non-framework because there's practically nothing in the stack outside of the
    precise problem domain - indeed there's nothing I could package up into a zip file
    as a framework - only a sample. The only templating used is to place JSON from
    the server into js vars. Even filling tables/lists is done client-side. Each page
    is a fully laid-out html document with empty form controls and/or tables which invokes
    the ajax services it needs and provides the navigation to and from itself as needed,
    and as yet I haven't built what I would call a "model" of the application on client
    OR server. Nearest relative would be the page-controller pattern. Of course on a
    multi-person project you would need either good team discipline and communication
    or maybe a client-side framework.

    ReplyDelete