jQuery vs. Prototype vs. _j (v26)

Revision 26 of this benchmark created by LZAntal on


Description

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

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/_j.min.js"></script>
<script>
$.noConflict();
</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

Revisions

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