Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Object filtering by key
(version: 1)
Compares different way to filter object
Comparing performance of:
Reduce (object) vs Reduce (Map) vs for-of (object) vs for-of (Map)
Created:
one year ago
by:
Guest
Jump to the latest result
Script Preparation code:
var data = { ...Array.from(Array(10000).keys()) };
Tests:
Reduce (object)
Object.keys(data) .filter(key => Number(key) % 2 === 0) .reduce((acc, key) => { acc[key] = data[key]; return acc; }, {});
Reduce (Map)
Object.keys(data) .filter(key => Number(key) % 2 === 0) .reduce((acc, key) => { acc.set(key, data[key]); return acc; }, new Map());
for-of (object)
const filter = (val) => { const result = {} for (const key in val) { if (Number(key) % 2 === 0) { continue; } result[key] = val[key]; } return result; };
for-of (Map)
const filter = (val) => { const result = new Map(); for (const key in val) { if (Number(key) % 2 === 0) { continue; } result.set(key, val[key]); } return Object.fromEntries(result.entries()); };
Rendered benchmark preparation results:
Suite status:
<idle, ready to run>
Run tests (4)
Previous results
Fork
Test case name
Result
Reduce (object)
Reduce (Map)
for-of (object)
for-of (Map)
Fastest:
N/A
Slowest:
N/A
Latest run results:
Run details:
(Test run date:
one year ago
)
User agent:
Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:136.0) Gecko/20100101 Firefox/136.0
Browser/OS:
Firefox 136 on Windows
View result in a separate tab
Embed
Embed Benchmark Result
Test name
Executions per second
Reduce (object)
2439.2 Ops/sec
Reduce (Map)
1638.2 Ops/sec
for-of (object)
1851825536.0 Ops/sec
for-of (Map)
1862645120.0 Ops/sec
Related benchmarks:
Object.fromEntries vs reduce vs Map
reduce vs filter 22
Object filter: fromEntries vs reduce
Object filter: fromEntries vs reduce (with keys & entries)
reduce vs map/filter --- filter and reshape
Object.fromEntries vs reduce for filtering keys
Map() vs Object() on write and read
filter vs reduce
Object filtering by key v2
Comments
Confirm delete:
Do you really want to delete benchmark?