DOM vs innerHTML (v6)

Revision 6 of this benchmark created by Arthur Schreiber on


Preparation HTML

<div id="main_node"></div>
<script>
  var node = document.getElementById('main_node');
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
DOM
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));
node.appendChild(document.createElement('div'));

node.innerHTML = '';
ready
innerHTML
node.innerHTML = '<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>';

node.innerHTML = '';
ready

Revisions

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