Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
.getElementsByClassName() vs. .querySelectorAll()
Show the performance impact of a live node list (.getElementsByClassName()) vs. a static node list (.querySelectorAll()).
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/18.3.1 Safari/605.1.15
Browser:
Safari 18
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
.getElementsByClassName()
306773.7 Ops/sec
.querySelectorAll()
17698132.0 Ops/sec
HTML Preparation code:
<div class="foo">test</div> <div class="bar">test</div> <div class="foo">test</div> <div class="bar">test</div> <div class="foo">test</div> <div class="bar">test</div> <div class="foo">test</div> <div class="bar">test</div> <div class="foo">test</div> <div class="bar">test</div>
Tests:
.getElementsByClassName()
Array.from(document.getElementsByClassName("foo")).forEach(item => {if(item.textContent === "test"){console.log("match")}});
.querySelectorAll()
document.querySelectorAll("foo").forEach(item => {if(item.textContent === "test"){console.log("match")}});