RightJS vs. YUI3 vs. jQuery vs. Sizzle vs. Peppy vs. Native selector test (v38)

Revision 38 of this benchmark created on


Description

Native case: * Reference matches after loop because a real function would need to return that. * Resubmiteed; DSL + 2Wire drops packets.

Preparation HTML

<script src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script src="http://yui.yahooapis.com/3.3.0/build/yui/yui-min.js"></script>
<script src="https://github.com/jquery/sizzle/raw/master/sizzle.js"></script>
<script src="http://jamesdonaghue.com/static/peppy/peppy-min.js"></script>
<script src="http://cdn.rightjs.org/right.js"></script>

<section class="target-me" name="donuts">.target-me</section>
<section class="target-me">.target-me</section>
<section class="target-me" name="candy">.target-me</section>
<script>
  jQuery.noConflict();
  Y = YUI().use('node');
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
jQuery
jQuery('.target-me[name=candy]');
ready
YUI3
Y.all('.target-me[name=candy]');
ready
Sizzle
Sizzle('.target-me[name=candy]');
ready
Peppy
peppy.query('.target-me[name=candy]');
ready
Native
var elements = document.getElementsByClassName('target-me'),
    i, j, len = elements.length,
    matches = [],
    e;

for (i = j = 0; i < len; ++i) {
 e = elements[i];
 if (e.getAttribute('name') === 'candy') {
  matches[j++] = e;
 }
}
matches;
ready
Native Query Selector
document.querySelectorAll('.target-me[name=candy]');
ready
RightJS
RightJS.$$('.target-me[name=candy]');
ready
Dojo 1.6
dojo.query('.target-me[name=candy]');
ready

Revisions

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