jquery selector speed

JavaScript performance comparison

Revision 45 of this test case created

Info

what about selecting on other attributes? Last version was broken

Preparation code

<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li class="target" id="target" an_attribute="target">
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>

<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>

<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>

<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>

<div id="container">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="targetid" class="target">
      2
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div><div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>
<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>
<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>
<div id="container1">
  <ul>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li id="foo">
      3
    </li>
    <li>
      1
    </li>
    <li id="one-two-three">
      3
    </li>
    <li id="targetid22">
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      1
    </li>
    <li class="target2">
      2
    </li>
    <li>
      3
    </li>
  </ul>
</div>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>

Preparation code output

  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 1
  • 2
  • 3

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in unknown unknown
Test Ops/sec
$('.target')
$('.target').css('border', '1px solid red');
pending…
$('#target')
$('#target').css('border', '1px solid red');
pending…
$('.target [an_attribute="target"]')
$('.target [an_attribute="target"]').css('border', '1px solid red');
pending…
$('#target [an_attribute="target"]')
$('#target [an_attribute="target"]').css('border', '1px solid red');
pending…
$('#container1 [an_attribute="target"]')
$('#container1 [an_attribute="target"]').css('border', '1px solid red');
pending…
getElementById
var e = document.getElementById('targetid');
$(e).css('border', '1px solid red');
pending…
$('[an_attribute=target]')
$('[an_attribute=target]').css('border', '1px solid red');
pending…
getElementsByClassName
var e = document.getElementsByClassName('target');
$(e).css('border', '1px solid red');
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. Here’s a list of current revisions for this page:

0 comments

Add a comment