Skip to content

Instantly share code, notes, and snippets.

@m1el
Created May 26, 2016 19:48
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save m1el/b28625b3b9261f0fab819e866133e49a to your computer and use it in GitHub Desktop.
Save m1el/b28625b3b9261f0fab819e866133e49a to your computer and use it in GitHub Desktop.
function render(obj) {
if (typeof obj === 'string') {
return new Text(obj);
} else if (Array.isArray(obj)) {
if (obj[0] === '!comment') {
return new Comment(obj[1]);
}
var dom = document.createElement(obj[0]);
var attrs = obj[1];
var keys = Object.keys(attrs);
var i, len;
for (i = 0, len = keys.length; i < len; i++) {
dom.setAttribute(keys[i], attrs[keys[i]]);
}
for (i = 2, len = obj.length; i < len; i++) {
dom.appendChild(render(obj[i]));
}
return dom;
} else {
throw 'Cannot make dom of: ' + obj;
}
}
var tmp, target;
var js = ['div', {}];
var i = 100;
while (--i) { js.push(['span', {'class': 'some classes'}, Array(100).join('Hello world!')]); }
var dom = render(js);
var html = dom.outerHTML;
i = 1e4;
target = document.createElement('div');
console.time('dom');
while (--i) {
target.appendChild(render(js));
target.removeChild(target.firstChild);
}
console.timeEnd('dom');
i = 1e4;
target = document.createElement('div');
console.time('innerHTML');
while (--i) {
target.innerHTML = html;
}
console.timeEnd('innerHTML');;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment