BSI.Node.append() vs jQuery.append() vs. Native DOM (v17)

Revision 17 of this benchmark created on


Preparation HTML

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>
<script src="http://bytes1.dyndns.org/BSI/website-app.js"></script>

Setup

var s = '<div id="response" class="quiet-scrollbars"><div id="tools"><a href="#" id="addButt"></a><a href="#" id="horzButt"></a><div class="divider"></div><div id="layoutText">LAYOUT</div><a href="#" class="vert-active" id="vertButt"></a><a href="#" id="inspectButton"></a><div id="inspectText">Inspect</div><div class="presetPos" id="button">PRESETS</div></div><div id="track"></div><input type="range" min="0" id="slider">';
  
  
  var domArray = [{tag:"div",attr:{id:"response", class:"quiet-scrollbars"}, parent:-1},{tag:"div",attr:{id:"tools"}, parent:0},{tag:"a",attr:{id:"addButt", href:"#"}, parent:1},{tag:"a",attr:{id:"horzButt", href:"#"}, parent:1},{tag:"a",attr:{class:"divider"}, parent:1},{tag:"a",attr:{class:"divider"}, parent:1},{tag:"div",attr:{id:"layoutText"}, text:"LAYOUT", parent:1},{tag:"a",attr:{id:"vertButt",class:"vert-active"}, parent:1},{tag:"div",attr:{id:"track"}, parent:0},{tag:"input",attr:{id:"slider",type:"range",min:"0"}, parent:0}];
  
  var d = document.createElement('div');
  document.body.appendChild(d);

Teardown



            document.body.removeChild(d);
        
  

Test runner

Ready to run.

Testing in
TestOps/sec
BSI.Node().append()
BSI.Node(d).append(s);
ready
BSI.util.makeDOMFragment
d.appendChild( BSI.util.makeDOMFragment(s) )
ready
DOM innerHTML
d.innerHTML = s;
ready
jQuery append
$(d).append(s);
ready
DOM Fragment
var frag = document.createDocumentFragment();
var elements = [];

while(domArray.length) {
  var el = domArray.shift();
  var element = document.createElement(el.tag);
  for(var a in el.attr) {
    element.setAttribute(a, el.attr[a]);
  }
  if(el.text) {
    element.appendChild(document.createTextNode(el.text));
  }
  elements.push(element);
                
  if(el.parent == -1)
     frag.appendChild(element);
  else
     elements[el.parent].appendChild(element);
}
d.appendChild(frag);
ready

Revisions

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