Goodby jQuery Templates, Hello JsRender

A funny thing happened on my way to the jQuery website, I blinked and a feature was dropped: jQuery Templates have been discontinued. The new pretender to the throne is JsRender.

jQuery Templates looked pretty useful when they first came out. Several articles were written about them but I stayed away because being on the bleeding edge of technology is not a productive place to be. I wanted to wait until it stabilized…in retrospect, it was a serendipitous decision.

This time however, I threw all caution to the wind and took a close look at JSRender. Why? Maybe I'm having a midlife crisis; I'll go motorcycle shopping tomorrow.

Caveat, here is a message from the site: Warning: JsRender is not yet Beta, and there may be frequent changes to APIs and features in the coming period.

Fair enough, we've been warned.

The first thing we need is some data to render. Below is some JSON formatted data. Typically this will come from an asynchronous call to a web service. For simplicity, I hard coded a variable:

    var Golfers = [
        { ID: "1", "Name": "Bobby Jones", "Birthday": "1902-03-17" },
        { ID: "2", "Name": "Sam Snead", "Birthday": "1912-05-27" },
        { ID: "3", "Name": "Tiger Woods", "Birthday": "1975-12-30" }
        ];

We also need some templates, I created two. Note: The script blocks have the id property set. They are needed so JsRender can locate them.

    <script id="GolferTemplate1" type="text/html">
        {{=ID}}: <b>{{=Name}}</b> <i>{{=Birthday}}</i> <br />
    </script>
 
    <script id="GolferTemplate2" type="text/html">
        <tr>
            <td>{{=ID}}</td> 
            <td><b>{{=Name}}</b></td> 
            <td><i>{{=Birthday}}</i> </td>
        </tr>
    </script>

Including the correct JavaScript files is trivial:

    <script src="Scripts/jquery-1.7.js" type="text/javascript"></script>
    <script src="Scripts/jsrender.js" type="text/javascript"></script>

Of course we need some place to render the output:

    <div id="GolferDiv"></div><br />
    <table id="GolferTable"></table>

The code is also trivial:

    function Test()
    {
        $("#GolferDiv").html($("#GolferTemplate1").render(Golfers));
        $("#GolferTable").html($("#GolferTemplate2").render(Golfers));
 
        // you can inspect the rendered html if there are poblems.
        // var html = $("#GolferTemplate2").render(Golfers);
    }

And here's what it looks like with some random CSS formatting that I had laying around.

 

 Not bad, I hope JsRender lasts longer than jQuery Templates.

One final warning, a lot of jQuery code is ugly, butt-ugly. If you do look inside the jQuery files, you may want to cover your keyboard with some plastic in case you get vertigo and blow chunks.

[Edit]

Someone asked me if it was possible to include the templates in an external file.  This seemed to work: 

<!--#include virtual="Scripts/RenderTemplates.js" -->

I hope someone finds this useful.

Steve Wellens

11 Comments

  • They should have adopted a more lean syntax, like Razor.

  • Hi Steve,
    That looks pretty much like jQuery templates...why would somebody wish to use jrender instead of it? Knockout uses jQuery templates for rendering (while the latest version is going to have its own templating engine) - is there a compelling reason for jsrender?

  • Shouldn't the template blocks have a type of "text/html" (or "text/x-jquery-tmpl" as the samples use)? If you leave it as "text/javascript", the browser will try to execute them.

  • &nbsp;&nbsp;&nbsp; &gt;&gt; That looks pretty much like jQuery
    &nbsp;&nbsp;&nbsp; &gt;&gt; templates...why would somebody wish to
    &nbsp;&nbsp;&nbsp; &gt;&gt; use jrender instead of it?

    Because jQuery templates are no longer supported.

    Here's the link: github.com/.../jquery-tmpl
    Oh yeah, and they are much faster.


  • &gt;&gt;Shouldn't the template blocks have a type of
    &gt;&gt;"text/html"(or "text/x-jquery-tmpl"
    &gt;&gt;as the samples use)?
    &gt;&gt;If you leave it as "text/javascript",
    &gt;&gt;the browser will try to execute them.

    RichardD, you are one sharp dude.

    When I used "text/x-jquery-tmpl" I got an HTML 5 validation error saying, "The values permitted for the attribute do not include "text/x-jquery-tmpl". &nbsp;

    What I had worked in IE and FF. &nbsp;But, I tried using "text/html" as you suggested and it also worked. &nbsp;I updated my post. &nbsp;Thanks friend!

  • jqTemplates was better, very disappointed this was dropped.

  • Nice one.
    How will you give column headings and border?

  • You have complete access to the HTML to add headings and of course CSS to add borders.

  • sorry I had to mention, this cracked me up
    "This time however, I threw all caution to the wind and took a close look at JSRender. Why? Maybe I'm having a midlife crisis; I'll go motorcycle shopping tomorrow."

    thanks for the tut

  • Thank for your share..

  • Do you know what?

    The new outlook.com implements Jquery template.

    Take a loot at the source code.

    You going to see what I'm talk about.

Comments have been disabled for this content.