Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
lodash/keyBy vs native reduce 2
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/129.0.0.0 Safari/537.36 Edg/129.0.0.0
Browser:
Chrome 129
Operating system:
Windows
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
lodash/keyBy
4995689.0 Ops/sec
keyBy with native reduce
6515550.5 Ops/sec
keyBy with forEach
3563646.5 Ops/sec
keyBy with for loop
5779602.5 Ops/sec
keyByReduce
1220464.9 Ops/sec
HTML Preparation code:
<script src='https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.5/lodash.min.js'></script>
Script Preparation code:
var data = [ { name: 'pi', value: 3.14 }, { name: 'hundred', value: 100 }, { name: 'truthy', value: true }, { name: 'falsy', value: false }, { name: 'estring', value: '2.71828' }, ]; var keyBy = (array, fn) => { return array.reduce((acc, value) => { acc[fn(value)] = value; return acc; }, {}); }; var keyByReduce = (array, key) => { return (array || []).reduce((r, x) => ({ ...r, [key ? x[key] : x]: x }), {}) } var keyByForEach = (array, fn) => { var acc = {}; _.forEach(array, (value) => { acc[fn(value)] = value; }); return acc; }; var keyByForLoop = (array, fn) => { var acc = {}; for (let i = 0; i < array.length; i++) { acc[fn(array[i])] = array[i]; } return acc; };
Tests:
lodash/keyBy
_.keyBy(data, (v) => v.name);
keyBy with native reduce
keyBy(data, (v) => v.name);
keyBy with forEach
keyByForEach(data, (v) => v.name);
keyBy with for loop
keyByForLoop(data, (v) => v.name);
keyByReduce
keyByReduce(data, 'name');