Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
for vs. for-in vs. for-of vs. reduce (map object values)
Make a new object by applying a function to each value of the source object.
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36
Browser:
Chrome 125
Operating system:
Windows
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
for loop
697936.9 Ops/sec
for-in loop
795116.4 Ops/sec
for-of loop
723214.9 Ops/sec
reduce
379899.1 Ops/sec
Script Preparation code:
var source = { "box-sizing": "border-box", "margin": 0, "padding": 0, "border-width": 0, "border-style": "solid", "border-color": "#ddd" } function iteratee(value) { return `${value} !important` }
Tests:
for loop
const sourceKeys = Object.keys(source) const result = {} for (let i = 0; i < sourceKeys.length; i++) { result[sourceKeys[i]] = iteratee(source[sourceKeys[i]]) }
for-in loop
const result = {} for (const key in source) { result[key] = iteratee(source[key]) }
for-of loop
const result = {} for (const key of Object.keys(source)) { result[key] = iteratee(source[key]) }
reduce
const result = Object.keys(source).reduce((memo, key) => { return { ...memo, [key]: iteratee(source[key]) } }, {})