jQuery (each & each2 & quickEach) vs. Prototype vs. _j (v33)

Revision 33 of this benchmark created on


Description

This is a comparison of selector engine speed between jQuery 2.0.3 and Prototype 1.6.1 and _j 0.4.3

Preparation HTML

<!doctype html>
<html>
<head>
<script src="//ajax.googleapis.com/ajax/libs/prototype/1.6.1/prototype.js">
</script>
<script src="//code.jquery.com/jquery-2.0.3.min.js"></script>
<script src="http://lzacorp.com/_jv0.4.3/_j.min.js"></script>
<script>
$.noConflict();
  var J = jQuery([1]);
        jQuery.fn.each2 = function(fn){//each2 with this as jQuery object ref
                var i=-1;//start from 0 by default or given position 
                while(
      (J.context = J[0] = this[++i]) && fn.call(J[0], i, J) !== false
    ){}
                return this;
        };
(function($)
{
        $.fn.quickEach = function(c)
        {
                var j = $([0]), i = -1, l = this.length;
                while(
                        ++i < l
                        && (j[0] = this[i])
                        && c.call(j, i, j[0]) !== false
                );
                return this;
        };
})(jQuery);
</script>
</head>
<body>
<ul id="list">
<li>
<ul class="sublist">
<li>
item1
</li>
<li>
item2
</li>
</ul>
</li>
<li>
<ul class="sublist">
<li>
item1
</li>
<li>
item2
</li>
</ul>
</li><li>
<ul class="sublist">
<li>
item1
</li>
<li>
item2
</li>
</ul>
</li><li>
<ul class="sublist">
<li>
item1
</li>
<li>
item2
</li>
</ul>
</li>
</ul>
</body>
</html>

Test runner

Ready to run.

Testing in
TestOps/sec
Prototype
$$("#list .sublist li").each(function(item) {
    Event.observe( $(item)
        .addClassName( 'cssclass' )
        .removeClassName( 'cssclass' )
    , 'click', function() {})
});
ready
_j
_jSel("#list .sublist li").forEach(function(item){
_jAddClass(item, "cssclass");
_jDelClass(item, "cssclass");
_jOn(item, "click", function(){});
});
ready
jQuery
jQuery("#list .sublist li").addClass( 'cssclass' ).removeClass( 'cssclass' ).click(function() {});
ready
_j native event handler
_jSel("#list .sublist li").forEach(function(item){
_jAddClass(item, "cssclass");
_jDelClass(item, "cssclass");
item.onclick = function(){};
});
ready
jQuery with each2
jQuery("#list .sublist li").each2(function(i,jq){
jq.addClass( 'cssclass' ).removeClass( 'cssclass' ).click(function() {});
});
ready
jQuery with quickEach
jQuery("#list .sublist li").quickEach(function(i,e){
this.addClass( 'cssclass' ).removeClass( 'cssclass' ).click(function() {});
});
ready
jQuery with each
jQuery("#list .sublist li").each(function(i,e){
jQuery(this).addClass( 'cssclass' ).removeClass( 'cssclass' ).click(function() {});
});
ready

Revisions

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