jQuery event delegation (v88)

Revision 88 of this benchmark created on


Description

Comparing performance of adding .click() to 100 table cells vs using .on() to listen for click events bubbling up the DOM tree.

Preparation HTML

<table>
  <tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr>
 <tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr><tr>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
    <td class="test">
    </td>
    <td>
    </td>
  </tr>
</table>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
no delegation
$('table').find('td').on('click', function() {
  $(this).toggleClass('active');
});
ready
with delegation
$('table').on('click', 'td', function() {
  var $this = $(this);
  if (!$this.hasClass('test')) {
    $this.toggleClass('active');
  }
});
ready
with not
$('table').on('click', 'td:not(.test)', function() {
  $(this).toggleClass('active');
});
ready

Revisions

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