Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Getting first element using querySelector vs querySelectorAll vs getElementsByClassName
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (X11; Linux x86_64; rv:146.0) Gecko/20100101 Firefox/146.0
Browser:
Firefox 146
Operating system:
Linux
Device Platform:
Desktop
Date tested:
4 months ago
Test name
Executions per second
querySelector()
6360135.0 Ops/sec
querySelectorAll()[0]
283136.8 Ops/sec
getElementsByClassname()[0]
7618184.5 Ops/sec
HTML Preparation code:
<div id="test-container"></div>
Script Preparation code:
{ const elementCount = 1000; const container = window.container = document.getElementById('test-container'); const fragment = document.createDocumentFragment(); const entities = window.entities = []; for (let i=0; i < elementCount; i++) { const element = document.createElement('div'); element.classList.add(`test-${i%4}`); element.setAttribute(`test`, i%4); fragment.append(element); entities.push(element); } container.append(fragment); }
Tests:
querySelector()
const randomID = 0|Math.random()*4; const result = window.container.querySelector(`.test-${randomID}`);
querySelectorAll()[0]
const randomID = 0|Math.random()*4; const result = window.container.querySelectorAll(`.test-${randomID}`)[0];
getElementsByClassname()[0]
const randomID = 0|Math.random()*4; const result = window.container.getElementsByClassName(`test-${randomID}`)[0];