如何在JavaScript中将对象数组转换为一个对象?

时间:2013-11-09 09:44:27

标签: javascript

我有一个对象数组:

[Object { key="11", value="1100", $$hashKey="00X"}, Object { key="22", value="2200", $$hashKey="018"}]

如何通过JavaScript将其转换为以下内容?

{"11":"1000", "22":"2200"}

15 个答案:

答案 0 :(得分:49)

Tiny ES6解决方案看起来像:

var arr = [{key:"11", value:"1100"},{key:"22", value:"2200"}];
var object = arr.reduce(
    (obj, item) => Object.assign(obj, {[item.key]: item.value}) ,{});

此外,如果你使用对象传播,它可能看起来像:

var object = arr.reduce((obj, item) => ({...obj, {[item.key]: item.value}}) ,{});

另一个快99%的解决方案是(在jsperf上测试):

var object = arr.reduce((obj, item) => (obj[item.key] = item.value, obj) ,{});

这里我们从逗号运算符中受益,它在逗号之前计算所有表达式并返回最后一个(在最后一个逗号之后)。因此,我们不是每次都复制obj,而是为其分配新属性。

答案 1 :(得分:46)

我喜欢实现此任务的功能方法:

var arr = [{ key:"11", value:"1100" }, { key:"22", value:"2200" }];
var result = arr.reduce(function(obj,item){
  obj[item.key] = item.value; 
  return obj;
}, {});

注意:最后{}是reduce函数的初始obj值,如果您不能提供第一个arr元素的初始值将被使用(这可能是不可取的)。

https://jsfiddle.net/GreQ/2xa078da/

答案 2 :(得分:28)

你可能正在寻找这样的东西:

// original
var arr = [ 
  {key : '11', value : '1100', $$hashKey : '00X' },
  {key : '22', value : '2200', $$hashKey : '018' }
];

//convert
var result = {};
for (var i=0; i<arr.length; i++) {
  result[arr[i].key] = arr[i].value;
}

//result
console.log(result);

答案 3 :(得分:19)

尝试修复this answer,应该这样做:

&#13;
&#13;
var array = [
    {key:'k1',value:'v1'},
    {key:'k2',value:'v2'},
    {key:'k3',value:'v3'}
];
var mapped = array .map(item => ({ [item.key]: item.value }) );
var newObj = Object.assign({}, ...mapped );
console.log(newObj );
&#13;
&#13;
&#13;

<小时/> 单行:

var newObj = Object.assign({}, ...(array.map(item => ({ [item.key]: item.value }) )));

答案 4 :(得分:8)

使用现代JavaScript的一种干净方法如下:

const array = [
  { name: "something", value: "something" },
  { name: "somethingElse", value: "something else" },
];

const newObject = Object.assign({}, ...array.map(item => ({ [item.name]: item.value })));

// >> { something: "something", somethingElse: "something else" }

答案 5 :(得分:7)

使用lodash

const obj = _.keyBy(arrayOfObjects, 'keyName')

答案 6 :(得分:5)

基于许多作者提出的答案,我创建了一个JsPref测试方案。 https://jsperf.com/array2object82364

下面是性能的屏幕截图。令我震惊的是,即使运行了几次,Chrome的效果也与Firefox和Edge相反。

Edge

Firefox

Chrome

答案 7 :(得分:2)

使用Underscore.js

SkyCoord

答案 8 :(得分:1)

使用Object.fromEntries

const array = [
    { key: "key1", value: "value1" },
    { key: "key2", value: "value2" },
];

const obj = Object.fromEntries(array.map(item => [item.key, item.value]));

console.log(obj);

答案 9 :(得分:0)

你走了:

var arr = [{ key: "11", value: "1100" }, { key: "22", value: "2200" }];
var result = {};
for (var i=0, len=arr.length; i < len; i++) {
    result[arr[i].key] = arr[i].value;
}
console.log(result); // {11: "1000", 22: "2200"}

答案 10 :(得分:0)

以下是如何动态接受上面的字符串并将其插入到对象中:

var stringObject = '[Object { key="11", value="1100", $$hashKey="00X"}, Object { key="22", value="2200", $$hashKey="018"}]';

function interpolateStringObject(stringObject) {
  var jsObj = {};
  var processedObj = stringObject.split("[Object { ");
  processedObj = processedObj[1].split("},");
  $.each(processedObj, function (i, v) {
      jsObj[v.split("key=")[1].split(",")[0]] = v.split("value=")[1].split(",")[0].replace(/\"/g,'');
  });

  return jsObj
}

var t = interpolateStringObject(stringObject); //t is the object you want

http://jsfiddle.net/3QKmX/1/

答案 11 :(得分:0)

// original
var arr = [{
    key: '11',
    value: '1100',
    $$hashKey: '00X'
  },
  {
    key: '22',
    value: '2200',
    $$hashKey: '018'
  }
];

// My solution
var obj = {};
for (let i = 0; i < arr.length; i++) {
  obj[arr[i].key] = arr[i].value;
}
console.log(obj)

答案 12 :(得分:0)

您可以为此使用mapKeys lodash函数。只需一行代码!

请参考完整的代码示例(将其复制粘贴到repl.it或类似文件中):

import _ from 'lodash';
// or commonjs:
// const _ = require('lodash');

let a = [{ id: 23, title: 'meat' }, { id: 45, title: 'fish' }, { id: 71, title: 'fruit' }]
let b = _.mapKeys(a, 'id');
console.log(b);
// b:
// { '23': { id: 23, title: 'meat' },
//   '45': { id: 45, title: 'fish' },
//   '71': { id: 71, title: 'fruit' } }

答案 13 :(得分:0)

您可以将一组对象合并为一行中的一个对象:

const obj = Object.assign({}, ...array);

答案 14 :(得分:-1)

        var obj = [
            {id: 1 , name : 'gaju' , class : 'kv'},
            {id: 2 , name : 'tushar' , class : 'Super'}
        ];

        function conv(obj,arg){
        var temp= {};
        var output= {}
        for(key in obj){
        temp[key] = obj[key];
        };

        var i=0;
        for(key in temp){
        var aa = {};
        var value = temp[key][arg];
        aa[value] = temp[i];
        //console.log(aa[value][arg] );
        output[aa[value][arg]]=  aa[value];
        i++;
        }

       console.log(output); 
        }

calling function 

    conv(obj,'class');