Imagine a review site where users enter ratings and optionally short comments.
On each review page you've got many comments - these are displayed in a table at the end of the page (btw - not looking for datagrid type controls, far too simple for that)
I want to let users enter new reviews and update the page without a page refresh.(all simple stuff so far, this is not the question)
What is a good approach to generating for the page. Some thoughts :-
Generate the reviews HTML server side, append new reviews using javascript client side. Downside is that you've got table HTML generation code in two places. Upside - more content on page as far as search engines concerned.
Server side only output reviews as json/xml/whatever and render HTML dynamically on page load using javasript.
Downside - 'template' in javascript, hard for designers to customize + lack of 'content' on page.
Is there an approach that combines the two methods - i.e. a templating framework that will render existing data server side but also sends the template fragment client side so it can be reused there for additions/edits.
With (2) to get the data on initial page load would you
a) include json/xml on initial page and run client side render on page load
b) get it via a separate AJAX call on page load (+ simpler, - extra request and delay)
I am focused on jQuery/Django but this question applies to other frameworks and AJAX libraries.
This is a bit of a subjective quesiton, hope it doesn't step over the line! Thoughts?
With a framework, an approach to your scenario (3) -- combining both methods -- is to use a view "partial". A partial is a fragment of a view that can be rendered on its own; a single view could be made up of several partials.
In your case, you'd define a partial to render a review. When showing the page from scratch, the server-side code loops through existing reviews and calls the partial to render them one after the other. When a new review is added to the existing page, the javascript asks the server to render just the partial for that new review and return it as an Ajax response, and then appends it to the existing reviews on the page.
You wouldn't necessarily have to know the template ahead of time, you'd just have to set hooks in the code for what data you want to fill in with JSON when you render your template.
The scenario would work like this:
I personally like keeping initial page load on the server-side for making it easier to cache pages and then only use AJAX for when you need to update the page or switch to a related page without the website having to reload.
An example for you:
<ul class="commentsArea">
    <li class="comment" data-commenter-id="user1234">
        <a href="#" class="userName">Rob</a>
        <p class="userCommentContent">Some comment content would go here.</p>
    </li>
</ul>
Then you'd have a templating function:
function template(comment, newCommentMetaData) {
    // comment is a cloned comment object
    // newCommentMetaData is the AJAX data
    comment.attr('data-commenter-id', newCommentMetaData.userid);
    comment.find('.userName').text(newCommentMetaData.name); 
    comment.find('.userCommentContent').text(newCommentMetaData.content); 
    return comment; 
}
Then finally you'd have to clone the comment to add new ones:
var newComment = $('li.comment:first').clone();
// fill in your AJAX data here
var newCommentMetaData = {
    userid: 'user2345',
    name: 'Pete',
    content: 'The new comment content goes here'
};
/* you would have to put an each() function here to iterate through all new comments
   and template them up, but hopefully you get the idea */
template(newComment, newCommentMetaData).appendTo('.commentsArea').fadeIn();
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With