Test name | Executions per second |
---|---|
getElementById() | 949884.9 Ops/sec |
getElementsByClassName() | 690786.4 Ops/sec |
getElementsByTagName() | 793317.1 Ops/sec |
querySelector(#id) | 465125.7 Ops/sec |
querySelector(.id) | 748408.5 Ops/sec |
querySelectorAll(#id) | 289016.4 Ops/sec |
querySelectorAll(.id) | 449361.0 Ops/sec |
jQuery(#id) | 310330.6 Ops/sec |
jQuery(.id) | 149143.7 Ops/sec |
jQuery(tag#id) | 93997.4 Ops/sec |
jQuery(tag.id) | 95644.6 Ops/sec |
jQuery + getElementById | 407501.6 Ops/sec |
jQuery + getElementsByClassName | 193889.6 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;