我有一个对象数组:
[
{ key : '11', value : '1100', $$hashKey : '00X' },
{ key : '22', value : '2200', $$hashKey : '018' }
];
如何使用JavaScript将其转换为如下形式?
{
"11": "1100",
"22": "2200"
}
我有一个对象数组:
[
{ key : '11', value : '1100', $$hashKey : '00X' },
{ key : '22', value : '2200', $$hashKey : '018' }
];
如何使用JavaScript将其转换为如下形式?
{
"11": "1100",
"22": "2200"
}
微小的ES6解决方案可能会像这样:
var arr = [{key:"11", value:"1100"},{key:"22", value:"2200"}];
var object = arr.reduce(
(obj, item) => Object.assign(obj, { [item.key]: item.value }), {});
console.log(object)
此外,如果您使用对象扩展语法,则可以看起来像:
var object = arr.reduce((obj, item) => ({...obj, [item.key]: item.value}) ,{});
还有一种解决方案,在jsperf测试结果中快了99%:
var object = arr.reduce((obj, item) => (obj[item.key] = item.value, obj) ,{});
在这里,我们受益于逗号运算符,它会在逗号之前计算所有的表达式,并返回最后一个(在最后一个逗号之后)。因此,我们不需要每次复制 obj
,而是给它分配新的属性。
var object = arr.reduce((obj, item) => (obj[item.key] = item.value, obj) ,{});
(说明:此代码为 JavaScript 语言代码,用于将一个数组转化为一个对象) - Sohail({...obj, ...{[item.key]: item.value}}) ,{});
- Juliavar object = arr.reduce((obj, item) => { obj[item.key] = item.value; return obj} ,{});
。 - kasvithvar 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 );
var newObj = Object.assign({}, ...(array.map(item => ({ [item.key]: item.value }) )));
你可能正在寻找这样的内容:
// 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;
}
console.log(result);
我喜欢采用功能性方法来完成这个任务:
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
元素(这可能是不希望的)。
const array = [
{ key: "key1", value: "value1" },
{ key: "key2", value: "value2" },
];
const obj = Object.fromEntries(array.map(item => [item.key, item.value]));
console.log(obj);
Array.map
的解决方案更清晰易读。 - Grant Humphries你可以将对象数组合并为一个对象,只需一行代码:
const obj = Object.assign({}, ...array);
使用现代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" }
使用lodash!
const obj = _.keyBy(arrayOfObjects, 'keyName')
使用reduce的简单方法
// Input :
const data = [{key: 'value'}, {otherKey: 'otherValue'}];
data.reduce((prev, curr) => ({...prev, ...curr}) , {});
// Output
{key: 'value', otherKey: 'otherValue'}
更简单的使用 Object.assign
Object.assign({}, ...array);
之前的答案
这里是:
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"}
array
是一个保留关键字,所以人们使用arr
代替。等等。 - pstadler
[{key:"11", value:"1100"}, {key:"22", value:"2200"}].reduce(function(m,v){m[v.key] = v.value; return m;}, {})
这段代码是将一个数组转换为一个对象。该对象的键是数组中每个元素的 "key" 属性,值是相应元素的 "value" 属性。在代码中,reduce
方法被用于迭代数组并构建最终的目标对象。 - david{ name: "Apple", value: "0.6" }
。如果你正在寻找另一种变体,其中结果是另一个具有单个属性的对象数组(例如[ { "11": "1100" }, { "22": "2200" } ]
),请参见如何将键值对对象数组转换为具有单个属性的对象数组?。 - Sebastian Simon