Skip to content

Instantly share code, notes, and snippets.

@josher19
Created January 12, 2012 01:32
Show Gist options
  • Save josher19/1597908 to your computer and use it in GitHub Desktop.
Save josher19/1597908 to your computer and use it in GitHub Desktop.
<!DOCTYPE html>
<html>
<head>
<base href="http://borismoore.github.com/jsviews/demos/jQueryConfDemosOct2011/14_custom-tags.html" />
<link href="../resources/demos.css" rel="stylesheet" type="text/css" />
<link href="../resources/movielist.css" rel="stylesheet" type="text/css" />
<link href="resources/syntaxhighlighter.css" rel="stylesheet" type="text/css" />
<script src="resources/syntaxhighlighter.min.js" type="text/javascript"></script>
<script src="http://code.jquery.com/jquery.js" type="text/javascript"></script>
<script src="../../jsrender.js" type="text/javascript"></script>
<script src="../../jquery.observable.js" type="text/javascript"></script>
<script src="../../jquery.views.js" type="text/javascript"></script>
</head>
<body>
<a href="13_allow-code.html">Prev</a> <a href="index.html">Home</a> <a href="16_and-MVVM-MVP-etc.html">Next</a><br />
<h3>18 Custom tags for rendering</h3>
<script id="movieTemplate" type="text/x-jquery-tmpl">
<tr>
<td>{{=Title}}</td>
<td>{{sort Languages tmpl="#sortedTemplate"}}</td>
<td>
{{#sort Languages reverse="true"}}
<div>
<b>{{=Name}}</b>
</div>
{{/sort}}
</td>
</tr>
</script>
<script id="sortedTemplate" type="text/x-jquery-tmpl">
<div>{{=Name}}</div>
</script>
<table><tbody class="header"><tr><th>Title</th><th>Orginal order</th><th>Reverse order</th></tr></tbody>
<tbody id="movieList"></tbody>
</table>
<script type="text/javascript">
$.views.registerTags({
sort: function( array ){
var ret = "";
if ( this.reverse === "true" ) {
// Render in reverse order
for ( var l = array.length, i = l; i; i-- ) {
ret += $.render( array[ i - 1 ], this.tmpl );
}
} else {
// Render in original order
ret += $.render( array, this.tmpl );
}
return ret;
}
});
var movies = [
{
Title: "Meet Joe Black",
Languages: [
{ Name: "English" },
{ Name: "French" }
]
},
{
Title: "Eyes Wide Shut",
Languages: [
{ Name: "French" },
{ Name: "German" },
{ Name: "Spanish" }
]
}
];
$( "#movieList" ).html(
$( "#movieTemplate" ).render( movies )
);
</script>
<!--================ End of Demo Section ================-->
<h4>HTML:</h4>
<pre class="brush: xml;">
&lt;td>
{{#sort Languages reverse="true"}}
&lt;div>{{=Name}}&lt;/div>
{{/sort}}
&lt;/td>
</pre>
<h4>Script:</h4>
<pre class="brush: js;">
$.views.registerTags({
sort: function( array ){
...
if ( this.reverse === "true" ) {
// Render in reverse order
for ( var l = array.length, i = l; i; i-- ) {
ret += $.render( array[ i - 1 ], this.tmpl );
}
}
...
return ret;
}
});
</pre>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment