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 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36
Browser:
Chrome 121
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
2 years ago
Test name
Executions per second
for loop
1654654.9 Ops/sec
for-in loop
1856765.0 Ops/sec
for-of loop
1654031.0 Ops/sec
reduce
805767.7 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]) } }, {})