Test name | Executions per second |
---|---|
getElementById() | 579743.9 Ops/sec |
getElementsByClassName() | 600708.9 Ops/sec |
getElementsByTagName() | 666701.3 Ops/sec |
querySelector(#id) | 738140.7 Ops/sec |
querySelector(.id) | 696842.0 Ops/sec |
querySelectorAll(#id) | 205550.6 Ops/sec |
querySelectorAll(.id) | 248829.5 Ops/sec |
jQuery(#id) | 719403.1 Ops/sec |
jQuery(.id) | 123691.5 Ops/sec |
jQuery(tag#id) | 64109.3 Ops/sec |
jQuery(tag.id) | 64540.8 Ops/sec |
jQuery + getElementById | 543411.7 Ops/sec |
jQuery + getElementsByClassName | 141357.8 Ops/sec |
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"><script>
<script>jQuery.noConflict();</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/cash/7.0.3/cash.min.js"></script>
<div id="foo" class="foo2"></div>
var el = document.getElementById("foo");
var className = el.className;
var el = document.getElementsByClassName("foo2");
var className = el.className;
var el = document.getElementsByTagName("div")[0];
var className = el.className;
var el = document.querySelector('#foo');
var className = el.className;
var el = document.querySelector('.foo2');
var className = el.className;
var el = document.querySelectorAll('#foo');
var className = el.className;
var el = document.querySelectorAll('.foo2');
var className = el.className;
var el = $("#foo");
var className = el.className;
var el = $(".foo2");
var className = el.className;
var el = $("div#foo");
var className = el.className;
var el = $("div.foo2");
var className = el.className;
var el = $(document.getElementById("foo"));
var className = el.className;
var el = $(document.getElementsByClassName("foo2"));
var className = el.className;
var el = jQuery("#foo");
var className = el.className;
var el = jQuery(".foo2");
var className = el.className;
var el = jQuery("div#foo");
var className = el.className;
var el = jQuery("div.foo2");
var className = el.className;
var el = jQuery(document.getElementById("foo"));
var className = el.className;
var el = jQuery(document.getElementsByClassName("foo2"));
var className = el.className;