Editing IE9 tweaking This edit will create a new revision. Your details (optional) Name Email (won’t be displayed; might be used for Gravatar) URL Test case details Title * Published (uncheck if you want to fiddle around before making the page public) Description (in case you feel further explanation is needed)(Markdown syntax is allowed) Trying to get it running in ie9 Are you a spammer? (just answer the question) Preparation code Preparation code HTML (this will be inserted in the <body> of a valid HTML5 document in standards mode) (useful when testing DOM operations or including libraries) <script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script> <script src="http://documentcloud.github.com/underscore/underscore.js"></script> <script src="http://github.com/janl/mustache.js/raw/master/mustache.js"></script> <script src="https://github.com/downloads/paul/handlebars.js/handlebars.js"></script> <script src="http://gist.github.com/raw/550881/29bb186167079c0b33ab6e9d50d779f37860cfa4/micro.js"></script> <script src="http://github.com/creationix/haml-js/raw/master/lib/haml.js"></script> <script src="http://gist.github.com/raw/550723/12d176698628e30a1df398c7ac7aea93924e1294/jade.js"></script> <script src="http://jashkenas.github.com/coffee-script/extras/coffee-script.js"></script> <script src="http://sstephenson.github.com/eco/dist/eco.js"></script> <script src="https://github.com/jquery/jquery-tmpl/raw/master/jquery.tmpl.min.js"></script> <script src="https://github.com/olado/doT/raw/master/doT.js"></script> <script src="https://github.com/olado/doT/raw/master/doU.js"></script> <script src="http://github.com/aefxx/jQote2/raw/69b2053a13f5f180e696de9b3dba856a3c00678c/jquery.jqote2.js"></script> <script src="http://embeddedjavascript.googlecode.com/files/ejs_0.9_alpha_1_production.js"></script> <script src="http://github.com/pure/pure/raw/master/libs/pure.js"></script> <div class="pure"> <h1 class='header'></h1> <h2 class='header2'></h2> <h3 class='header3'></h3> <h4 class='header4'></h4> <h5 class='header5'></h5> <h6 class='header6'></h6> <ul class='list'> <li class='item'></li> </ul> </div> <script src="https://github.com/rudenoise/LT.JS/raw/master/lt.js"></script> <script src="https://github.com/douglascrockford/JSON-js/raw/master/json2.js"></script> <script src="https://gist.github.com/raw/931033/7348f369acf3a2bf3f00fee0f4f5e4198585d4bf/jtemplates.js"></script> <script> var mustacheTemplate = "<div><h1 class='header'>{{header}}</h1><h2 class='header2'>{{header2}}</h2><h3 class='header3'>{{header3}}</h3><h4 class='header4'>{{header4}}</h4><h5 class='header5'>{{header5}}</h5><h6 class='header6'>{{header6}}</h6><ul class='list'>{{#list}}<li class='item'>{{.}}</li>{{/list}}</ul></div>"; var handlebarsTemplate = Handlebars.compile("<div><h1 class='header'>{{header}}</h1><h2 class='header2'>{{header2}}</h2><h3 class='header3'>{{header3}}</h3><h4 class='header4'>{{header4}}</h4><h5 class='header5'>{{header5}}</h5><h6 class='header6'>{{header6}}</h6><ul class='list'>{{#each list}}<li class='item'>{{this}}</li>{{/each}}</ul></div>"); var micro = "<div><h1 class='header'><%= header %></h1><h2 class='header2'><%= header2 %></h2><h3 class='header3'><%= header3 %></h3><h4 class='header4'><%= header4 %></h4><h5 class='header5'><%= header5 %></h5><h6 class='header6'><%= header6 %></h6><ul class='list'><% for (var i = 0, l = list.length; i < l; i++) { %><li class='item'><%= list[i] %></li><% } %></ul></div>"; var underscoreTemplate = _.template(micro); var resigTemplate = tmpl(micro); var sharedVariables = { header: "Header", header2: "Header2", header3: "Header3", header4: "Header4", header5: "Header5", header6: "Header6", list: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10'] }; var 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"; var hamlTemplate = Haml("%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"); var ecoTemplate = eco("<div><h1 class='header'><%- @header %></h1><h2 class='header2'><%- @header2 %></h2><h3 class='header3'><%- @header3 %></h3><h4 class='header4'><%- @header4 %></h4><h5 class='header5'><%- @header5 %></h5><h6 class='header6'><%- @header6 %></h6><ul class='list'><% for item in @list: %><li class='item'><%- item %></li><% end %></ul></div>"); var jQueryTemplate = $.template(null, "<div><h1 class='header'>{header}</h1><h2 class='header2'>{header2}</h2><h3 class='header3'>{header3}</h3><h4 class='header4'>{header4}</h4><h5 class='header5'>{header5}</h5><h6 class='header6'>{header6}</h6><ul class='list'>{{each list}}<li class='item'>{{html $value}}</li>{{/each}}</ul></div>"); var doTtemplate = doT.template("<div><h1 class='header'>{{= it.header }}</h1><h2 class='header2'>{{= it.header2 }}</h2><h3 class='header3'>{{= it.header3 }}</h3><h4 class='header4'>{{= it.header4 }}</h4><h5 class='header5'>{{= it.header5 }}</h5><h6 class='header6'>{{= it.header6 }}</h6><ul class='list'>{{ for (var i = 0, l = it.list.length; i < l; i++) { }}<li class='item'>{{= it.list[i] }}</li>{{ } }}</ul></div>"); var doUtemplate = doU.template("<div><h1 class='header'>{{= it.header }}</h1><h2 class='header2'>{{= it.header2 }}</h2><h3 class='header3'>{{= it.header3 }}</h3><h4 class='header4'>{{= it.header4 }}</h4><h5 class='header5'>{{= it.header5 }}</h5><h6 class='header6'>{{= it.header6 }}</h6><ul class='list'>{{ for (var i = 0, l = it.list.length; i < l; i++) { }}<li class='item'>{{= it.list[i] }}</li>{{ } }}</ul></div>"); var jqote_tmpl = "<div><h1 class='header'><%= this.header %></h1><h2 class='header2'><%= this.header2 %></h2><h3 class='header3'><%= this.header3 %></h3><h4 class='header4'><%= this.header4 %></h4><h5 class='header5'><%= this.header5 %></h5><h6 class='header6'><%= this.header6 %></h6><ul class='list'><% for (var n = 0, l = this.list.length; n < l; n++) { %><li class='item'><%= this.list[n] %></li><% } %></ul></div>"; var jqote2 = $.jqotec(jqote_tmpl); var ejs = new EJS({ text: micro }); var baseHtml = "<div><h1 class='header'></h1><h2 class='header2'></h2><h3 class='header3'></h3><h4 class='header4'></h4><h5 class='header5'></h5><h6 class='header6'></h6><ul class='list'><li class='item'></li></ul></div>"; var pureTemplate = $p('div.pure').compile({ h1: 'header', h2: 'header2', h3: 'header3', h4: 'header4', h5: 'header5', h6: 'header6', li: { 'itm<-list': { '.': 'itm' } } }); var hamlTemplate_2 = "%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"; window.hamlCompiled = Haml.compile(hamlTemplate_2); window.hamlOptimized = Haml.optimize(hamlCompiled); var ltTemplate = function(data) { return lt([ ['h1', { class: 'header' }, data.header], ['h2', { class: 'header2' }, data.header2], ['h3', { class: 'header3' }, data.header3], ['h4', { class: 'header4' }, data.header4], ['h5', { class: 'header5' }, data.header5], ['h6', { class: 'header6' }, data.header6], ['ul', (function(ls) { var rtn = [], i, l = ls.length; for (i = 0; i < l; i += 1) { rtn.push(['li', { class: 'item' }, (ls[i] + '')]); } return rtn; }(data.list))] ]); }; var jTemplatesTemplate = "<div><h1 class='header'>{$T.header}</h1><h2 class='header2'>{$T.header2}</h2><h3 class='header3'>{$T.header3}</h3><h4 class='header4'>{$T.header4}</h4><h5 class='header5'>{$T.header5}</h5><h6 class='header6'>{$T.header6}</h6><ul class='list'>{#foreach $T.list as item}<li class='item'>{$T.item}</li>{#/for}}</ul></div>"; var jtemplate = jQuery.createTemplate(jTemplatesTemplate); </script> Include JavaScript libraries as follows: <script src="//cdn.ext/library.js"></script> Define setup for all tests (variables, functions, arrays or other objects that will be used in the tests) (runs before each clocked test loop, outside of the timed code region) (e.g. define local test variables, reset global variables, clear canvas, etc.) (see FAQ) Define teardown for all tests (runs after each clocked test loop, outside of the timed code region) (see FAQ) Code snippets to compare Test 1 Title Async (check if this is an asynchronous test) Code Mustache.to_html(mustacheTemplate, sharedVariables); Test 2 Title Async (check if this is an asynchronous test) Code resigTemplate(sharedVariables); Test 3 Title Async (check if this is an asynchronous test) Code hamlTemplate(sharedVariables); Test 4 Title Async (check if this is an asynchronous test) Code jade.render(jadeTemplate, { locals: sharedVariables, filename: 'test.js', cache: true }); Test 5 Title Async (check if this is an asynchronous test) Code underscoreTemplate(sharedVariables); Test 6 Title Async (check if this is an asynchronous test) Code ecoTemplate(sharedVariables); Test 7 Title Async (check if this is an asynchronous test) Code jQueryTemplate($, { data: sharedVariables }).join(""); Test 8 Title Async (check if this is an asynchronous test) Code handlebarsTemplate(sharedVariables); Test 9 Title Async (check if this is an asynchronous test) Code doTtemplate(sharedVariables); Test 10 Title Async (check if this is an asynchronous test) Code doUtemplate(sharedVariables); Test 11 Title Async (check if this is an asynchronous test) Code jqote2.call(sharedVariables, 0, 0, [sharedVariables], jqote2); Test 12 Title Async (check if this is an asynchronous test) Code ejs.render(sharedVariables); Test 13 Title Async (check if this is an asynchronous test) Code pureTemplate(sharedVariables); Test 14 Title Async (check if this is an asynchronous test) Code Haml.execute(window.hamlOptimized, sharedVariables, sharedVariables); Test 15 Title Async (check if this is an asynchronous test) Code lt.render(ltTemplate, sharedVariables); Test 16 Title Async (check if this is an asynchronous test) Code jQuery.processTemplateToText(jtemplate, sharedVariables);