Run details:
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.0.0 Safari/537.36
Chrome 102
Windows
Desktop
2 years ago
Test name Executions per second
Object.fromEntries 1060.2 Ops/sec
Reduce (reuse object) 6331.0 Ops/sec
Reduce (creating temporary objects) 58.7 Ops/sec
Map 1409.9 Ops/sec
forEach 6437.8 Ops/sec
for of 7371.7 Ops/sec
for i 630.5 Ops/sec
for i saved length variable 1153.7 Ops/sec
Script Preparation code:
AخA
 
var data = Array.from(Array(10000).keys()).map(i => ({id: i, value: `val_${i}`}));
Tests:
  • Object.fromEntries

     
    Object.fromEntries(data.map(obj => [obj.id, obj]));
  • Reduce (reuse object)

     
    data.reduce((acc, obj) => {
      acc[obj.id] = obj;
      return acc;
    }, {});
  • Reduce (creating temporary objects)

     
    data.reduce((acc, obj) => ({
      ...acc,
      [obj.id]: obj
    }), {});
  • Map

     
    new Map(data.map(obj => [obj.id, obj]));
  • forEach

     
    const res = {};
    data.forEach(obj => {
        res[obj.id] = obj; 
    });  
  • for of

     
    const res = {};
    for (const obj of data) {
        res[obj.id] = obj; 
    }  
  • for i

     
    const res = {};
    for (let i = 0; i < data.length; i++) {
        const obj = data[i];
        res[obj.id] = obj; 
    }  
  • for i saved length variable

     
    const res = {};
    const length = data.length;
    for (let i = 0; i < length; i++) {
        const obj = data[i];
        res[obj.id] = obj; 
    }