ES6 / ES2015에서 당신의 사용을 결합 할 수 있습니다 Object.keys 및 감소 새로운와 Object.assign 기능, 화살표 기능 및 계산 된 속성 이름 매우 간단 하나의 명령문 솔루션.
const foo = { a: 1, b: 2, c: 3 };
const bar = Object.keys(foo)
.reduce((obj, key) => Object.assign({}, obj, { [foo[key]]: key }), {});
객체 확산 연산자 (이 글을 쓰는 시점에서 3 단계)를 사용하여 트랜스 파일하는 경우 작업을 좀 더 단순화합니다.
const foo = { a: 1, b: 2, c: 3 };
const bar = Object.keys(foo)
.reduce((obj, key) => ({ ...obj, [foo[key]]: key }), {});
마지막으로 Object.entries를 사용할 수있는 경우 (작성 당시 4 단계) 로직을 한 번 더 정리 (IMO) 할 수 있습니다.
const foo = { a: 1, b: 2, c: 3 };
const bar = Object.entries(foo)
.reduce((obj, [key, value]) => ({ ...obj, [value]: key }), {});