JavaScript template language shootoff

JavaScript performance comparison

Revision 254 of this test case created by Lance Pollard

Preparation code


<script src="https://raw.github.com/visionmedia/jade/b69aea3c1c0f93419d1d87f74f24c9dcee33fcdd/jade.js"></script>

<script>
  console.log(require)
  window.jade = require('jade');
  window.sharedVariables = {
   header: "Header",
   header2: "Header2",
   header3: "Header3",
   header4: "Header4",
   header5: "Header5",
   header6: "Header6",
   list: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10']
  };
  
  window.jupTemplate = ['div', ['h1',
  {
   'class': 'header'
  }, "{{header}}"],
   ['h2',
   {
    'class': 'header2'
   }, "{{header2}}"],
   ['h3',
   {
    'class': 'header3'
   }, "{{header3}}"],
   ['h4',
   {
    'class': 'header4'
   }, "{{header4}}"],
   ['h5',
   {
    'class': 'header5'
   }, "{{header5}}"],
   ['h6',
   {
    'class': 'header6'
   }, "{{header6}}"],
   ['ul',
   {
    'class': 'list'
   }, ['li',
   {
    'class': 'item'
   }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item'
    }, '{{list}}'],
    ['li',
    {
     'class': 'item}'
    }, '{{list}}']
   ]
  ];
  
  window.jadeTemplate = "div\n  h1.header!= header\n  h2.header2!= header2\n  h3.header3!= header3\n  h4.header4!= header4\n  h5.header5!= header5\n  h6.header6!= header6\n  ul.list\n    - each item in list\n      li.item!= item";
  
</script>
    

Preparation code output

<script> console.log(require) window.jade = require('jade'); window.sharedVariables = { header: "Header", header2: "Header2", header3: "Header3", header4: "Header4", header5: "Header5", header6: "Header6", list: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10'] }; window.jupTemplate = ['div', ['h1', { 'class': 'header' }, "{{header}}"], ['h2', { 'class': 'header2' }, "{{header2}}"], ['h3', { 'class': 'header3' }, "{{header3}}"], ['h4', { 'class': 'header4' }, "{{header4}}"], ['h5', { 'class': 'header5' }, "{{header5}}"], ['h6', { 'class': 'header6' }, "{{header6}}"], ['ul', { 'class': 'list' }, ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item' }, '{{list}}'], ['li', { 'class': 'item}' }, '{{list}}'] ] ]; window.jadeTemplate = "div\n h1.header!= header\n h2.header2!= header2\n h3.header3!= header3\n h4.header4!= header4\n h5.header5!= header5\n h6.header6!= header6\n ul.list\n - each item in list\n li.item!= item"; </script>

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in CCBot 2.0.0 / Other 0.0.0
Test Ops/sec
Mustache.js Template
Mustache.to_html(mustacheTemplate, sharedVariables);
pending…
Resig Micro-Templating.
resigTemplate(sharedVariables);
pending…
Creationix's Haml-js Template
hamlTemplate(sharedVariables);
pending…
Jade Template
jade.render(jadeTemplate, {
 locals: sharedVariables,
 filename: 'test.js',
 cache: true,
 client: true
});
pending…
JUP Template
JUP.html([sharedVariables], jupTemplate);
pending…
Underscore.js Template
underscoreTemplate(sharedVariables);
pending…
Eco Template
ecoTemplate(sharedVariables);
pending…
jQuery Templates
$.tmpl(jQueryTemplate, sharedVariables);
pending…
Handlebars.js
handlebarsTemplate(sharedVariables);
pending…
doT.js
doTtemplate(sharedVariables);
pending…
doU.js
doUtemplate(sharedVariables);
pending…
jQote2 direct
jqote2.call(sharedVariables, 0, 0, [sharedVariables], jqote2);
pending…

Compare results of other browsers

Revisions

You can edit these tests or add even more tests to this page by appending /edit to the URL.

0 Comments