jquery selector speed (v45)

Revision 45 of this benchmark created on


Description

what about selecting on other attributes? Last version was broken

Preparation HTML

<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>

Test runner

Ready to run.

Testing in
TestOps/sec
$('.target')
$('.target').css('border', '1px solid red');
ready
$('#target')
$('#target').css('border', '1px solid red');
ready
$('.target [an_attribute="target"]')
$('.target [an_attribute="target"]').css('border', '1px solid red');
ready
$('#target [an_attribute="target"]')
$('#target [an_attribute="target"]').css('border', '1px solid red');
ready
$('#container1 [an_attribute="target"]')
$('#container1 [an_attribute="target"]').css('border', '1px solid red');
ready
getElementById
var e = document.getElementById('targetid');
$(e).css('border', '1px solid red');
ready
$('[an_attribute=target]')
$('[an_attribute=target]').css('border', '1px solid red');
ready
getElementsByClassName
var e = document.getElementsByClassName('target');
$(e).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.