jquery selector speed (v14)

Revision 14 of this benchmark created on


Preparation HTML

<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 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 id="targetid">
      3
    </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>

Test runner

Ready to run.

Testing in
TestOps/sec
$('div#container ul li.target')
$('div#container ul li.target').css('border', '1px solid red');
ready
$('#container .target')
$('#container .target').css('border', '1px solid red');
ready
$('.target:eq(0)')
$('.target:eq(0)').css('border', '1px solid red');
ready
$('.target')
$('.target').css('border', '1px solid red');
ready
$('.target:first')
$('.target:first').css('border', '1px solid red');
ready
$('#targetid')
$('#targetid').css('border', '1px solid red');
ready
getElementById
var e = document.getElementById('targetid');
$(e).css('border', '1px solid red');
ready
$('li#targetid')
$('li#targetid').css('border', '1px solid red');
ready

Revisions

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