Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Array.from(NodeList).map vs [...NodeList].map vs map.call(NodeList) vs. NodeList#map copied from Array vs for loop
Different methods of mapping a node list.
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36
Browser:
Chrome 120
Operating system:
Linux
Device Platform:
Desktop
Date tested:
2 years ago
Test name
Executions per second
Array.from(NodeList).map
453961.3 Ops/sec
[...NodeList].map
592358.7 Ops/sec
map.call(NodeList)
537251.8 Ops/sec
NodeList#map
596202.1 Ops/sec
for loop
669248.3 Ops/sec
Script Preparation code:
NodeList.prototype.map = Array.prototype.map; window.list = document.querySelectorAll('div'); window.mapper = node => node.outerHTML;
Tests:
Array.from(NodeList).map
Array.from(list).map(mapper);
[...NodeList].map
[...list].map(mapper);
map.call(NodeList)
Array.prototype.map.call(list, mapper);
NodeList#map
list.map(mapper);
for loop
const result = []; for (let i = 0; i < list.length; i++) result.push(mapper(list[i], i, list));