[英]Javascript underscore array to object
是否有一種簡單/干凈的方式使用Underscore來解決這個問題
[ { id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 } ]
成
{ 'low' : 9,
'medium' : 7,
'high' : 5 }
你可以考慮_.indexBy(...)
var data = [{
id: 1,
name: 'Jon Doe',
birthdate: '1/1/1991',
height: '5 11'
}, {
id: 2,
name: 'Jane Smith',
birthdate: '1/1/1981',
height: '5 6'
}, {
id: 3,
name: 'Rockin Joe',
birthdate: '4/4/1994',
height: '6 1'
}, {
id: 4,
name: 'Jane Blane',
birthdate: '1/1/1971',
height: '5 9'
}, ];
var transformed = _.indexBy(data, 'id');
這是一個小提琴: https : //jsfiddle.net/4vyLtcrf/3/
更新:在Lodash 4.0.1中,方法_.indexBy已重命名為_.keyBy
var data = [ { id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 } ];
您可以使用_.map
, _.values
和_.object
這樣做
console.log(_.object(_.map(data, _.values)));
# { medium: 7, low: 9, high: 5 }
說明
我們使用map
函數將values
函數(它獲取給定對象的所有值)應用於data
所有元素,這將給出
# [ [ 'medium', 7 ], [ 'low', 9 ], [ 'high', 5 ] ]
然后我們使用object
函數將其轉換為對象。
這是與香草js:
var result = {};
[ { id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 } ].forEach(function(obj) {
result[obj.id] = obj.votes;
});
console.log(result);
對我來說更簡單: each
:
var t = {};
_.each(x, function(e){
t[e.id] = e.votes;
});
//--> {medium: 7, low: 9, high: 5}
最強大的下划線方法是減少。 你幾乎可以做任何事情。 更大的好處是你只需要在ONCE上迭代!
var array = [
{ id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 }
];
var object = _.reduce(array, function(_object, item) {
_object[item.id] = item.votes;
return _object;
}, {});
運行后,對象將是:
{
medium:7,
low:9,
high:5
}
使用indexBy
_.indexBy([
{ id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 }
], 'id');
我知道這是一個舊帖子,但您可以使用_.reduce
以干凈的方式進行轉換
var data = [
{ id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 }
]
var output = _.reduce(data, function(memo, entry) {
memo[entry.id] = entry.votes;
return memo;
}, {});
console.log(output);
您可以使用本機JS Array.reduce執行此操作
const myArray = [ { id: 'medium', votes: 7 },
{ id: 'low', votes: 9 },
{ id: 'high', votes: 5 } ]
const myObject = myArray.reduce((obj, item)=>{
o[item.id] = item.votes
return o
}, {})
有關詳細信息,請查看https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.