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; rv:108.0) Gecko/20100101 Firefox/108.0
Browser:
Firefox 108
Operating system:
Linux
Device Platform:
Desktop
Date tested:
2 years ago
Test name
Executions per second
Array.from(NodeList).map
1501167.2 Ops/sec
[...NodeList].map
1522072.1 Ops/sec
map.call(NodeList)
1632354.1 Ops/sec
NodeList#map
1571216.9 Ops/sec
for loop
1577164.8 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));