다음과 같은 추가 객체가 포함 된 배열이있는 간단한 JSON이 있습니다.
languagePack:
[
{
'key': 'Username',
'value': 'Benutzername',
'group': 'default'
},
{
'key': 'Password',
'value': 'Passwort',
'group': 'default'
}
]
그러나 내가 정말로 원하는 것은 다음과 같은 객체입니다.
languagePack:
{
'Username': 'Benutzername',
'Password': 'Passwort'
}
그래서 배열을 배열이나 객체 내부의 간단한 키-값 쌍으로 줄이고 싶습니다 (키는 고유합니다). 이 멋진 배열 기능 중 일부를 사용하여 이것을 줄이는 방법을 아는 사람이 있습니까? 나는 단지 각각에 대한 것과 같은 것을 생각해 내고 속성에 대한 “손으로”속성 속성을 만들었지 만 ‘reduce’, 스프레드 연산자 (…), map, every, 일부 등
나는 다음과 같이 시도했다.
var temp = this.languagePack.map(([key, value]) => ({key,value}))
console.log(temp)
그러나 그것은 단지 나에게 오류 메시지를 얻었다 TypeError: Invalid attempt to destructure non-iterable instance
편집 : 세 가지 답변 모두 완벽하게 작동합니다. 감사.
답변
기본적으로 함수 forEach
대신 사용해야 map
하며 키, 값 쌍을 유지하려는 객체로 객체를 빌드 할 수 있습니다.
이것을 시도하면 문제가 해결됩니다.
var temp = {};
this.languagePack.forEach(({key,value}) => {
temp[key] = value
})
console.log(temp)
참고 : 여기서는 map
배열이 아닌 객체를 반환하기 때문에 사용 reduce
하지 않으므로 여기에서 함수 를 사용 하면됩니다. 그러나 이것이 우리가 원하는 것과 여기에서하는 일을 간단하고 이해하기 쉽다고 생각했습니다.
답변
javascript reduce
함수를 사용하여 빈 객체를 만들고 각 키와 값을 넣을 수 있습니다.
const data = [
{
'key': 'Username',
'value': 'Benutzername',
'group': 'default'
},
{
'key': 'Password',
'value': 'Passwort',
'group': 'default'
}
];
const newData = data.reduce((acc, row) => {
acc[row.key] = row.value;
return acc;
}, {});
console.log(newData);
편집 : Donny Verduijn 의 좋은 제안 . es6 소멸을 사용하여 함수를 더 짧게 작성할 수 있습니다.
const newData = data.reduce((acc, { key, value }) => ({ ...acc, [key]: value }), {});
답변
함께 사용 Array#map
의 개체와 같은 키와 값 생성 Object.assign
객체 비밀 어레이 값
const languagePack = [ { 'key': 'Username', 'value': 'Benutzername', 'group': 'default' }, { 'key': 'Password', 'value': 'Passwort', 'group': 'default' } ];
var res = Object.assign({},...languagePack.map(({key,value}) => ({[key]:value})))
console.log(res)
답변
ES6 Map
을 사용 Object.fromEntries
하여로 map
다시 변환 할 수 있습니다 Object
.
지도에 대한 자세한 내용
let languagePack=
[{
'key': 'Username',
'value': 'Benutzername',
'group': 'default'
},
{
'key': 'Password',
'value': 'Passwort',
'group': 'default'
}];
let map = new Map();
languagePack.forEach((val)=>{
map.set(val.key, val.value);
})
languagePack = Object.fromEntries(map);
console.log(languagePack);