jQuery VS Zepto VS Angular jqLite

JavaScript performance comparison

Revision 171 of this test case created by

Preparation code

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.6/angular.min.js"></script>
<script src="https://code.jquery.com/jquery-git2.min.js"></script>
<script src="https://zeptojs.com/zepto.min.js"></script>
<script src="https://fastjs.net/js/fast.min.js"></script>
<script src="https://rawgithub.com/01org/appframework/master/appframework.min.js"></script>
<script src="https://bytes1.dyndns.org/BSI/website-app.js"></script>


<div id="container"></div>
      
<script>
Benchmark.prototype.setup = function() {
  var container = document.getElementById('container');
  var ul, li, i = 0;
  var msg = "Hello World ";
  
  var div = document.createElement('div');
  
  function htmlToFragment(html) {
    div.innerHTML = html;
    var fragment = document.createDocumentFragment();
    for (var i = -1, c = div.childNodes.length; ++i < c;) {
      fragment.appendChild(div.childNodes[i]);
    }
    return fragment;
  }

};

Benchmark.prototype.teardown = function() {
  container.innerHTML = "";

};
</script>

Preparation code output

<script src="https://code.jquery.com/jquery-git2.min.js"></script> <script src="https://zeptojs.com/zepto.min.js"></script> <script src="https://fastjs.net/js/fast.min.js"></script> <script src="https://rawgithub.com/01org/appframework/master/appframework.min.js"></script> <script src="https://bytes1.dyndns.org/BSI/website-app.js"></script> <div id="container"></div>

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
jQuery
ul = jQuery("<ul>");
for (; i < 100; i++) {
  ul.append("<li>" + msg + "jQuery</li>");
}
jQuery(container).append(ul);
pending…
Intel App Framework
ul = af("<ul>");
for (; i < 100; i++) {
  ul.append("<li>" + msg + "AppFW</li>");
}
af(container).append(ul);
pending…
Zepto
ul = Zepto("<ul>");
for (; i < 100; i++) {
  ul.append("<li>" + msg + "Zepto</li>");
}
Zepto(container).append(ul);
pending…
Angular jqLite
ul = angular.element("<ul>");
for (; i < 100; i++) {
  ul.append(angular.element("<li>" + msg + "Angular</li>"));
}
angular.element(container).append(ul);
pending…
BSI
ul = BSI.makeNode("ul");
for (; i < 1; i++) {
  ul.append(BSI.util.makeDOMFragment("<li>" + msg + "BSI</li>"));
}
BSI.Node(container).append(ul);
pending…
fastjs
ul = f.create("<ul>");
for (; i < 100; i++) {
  f.append(ul, f.create("<li>" + msg + "FastJS</li>"));
}
f.append(container, ul);
pending…
"native"
ul = htmlToFragment("<ul/>");
for (; i < 100; i++) {
  ul.appendChild(htmlToFragment("<li>" + msg + "'native'</li>"));
}
container.appendChild(ul)
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