일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 백준
- react
- TypeScript
- 자바스크립트
- next.js
- 이더리움
- 웹
- VUE
- docker
- 컴퓨터공학
- 블록체인
- 이슈
- 쿠버네티스
- 프론트엔드
- 타입스크립트
- BFS
- 가상화
- 클라우드
- 리액트
- es6
- k8s
- 솔리디티
- JavaScript
- CSS
- 백엔드
- kubernetes
- AWS
- 파이썬
- 알고리즘
- HTML
Archives
- Today
- Total
즐겁게, 코드
keys, values, entries 메서드 사용하기 본문
개발을 하다보면 객체를 배열로 바꿔야 할 때, 객체의 키만 필요할 때, 값만 필요할 때 등등 객체와 배열을 넘나들어야 하는 상황이 자주 생깁니다.
객체의 키 목록 추출하기
먼저 객체의 키 목록을 추출하는 경우입니다.Object.keys(대상 객체명)
은 해당 객체가 갖는 키의 목록을 배열로 반환합니다.
const productList = {
backpack: 1200,
pencil: 800,
eraser: 600,
}
Object.keys(productList) // [ 'backpack', 'pencil', 'eraser' ]
객체의 값 목록 추출하기
객체의 값만을 배열로 뽑아낼 수도 있습니다.Object.values(대상 객체명)
은 해당 객체가 갖는 값의 목록을 배열로 반환합니다.
const productList = {
backpack: 1200,
pencil: 800,
eraser: 600,
}
Object.values(productList) // [ 1200, 800, 600 ]
객체를 배열로 변환하기
이제 이를 사용해 객체를 배열의 형태로 변환할 수 있습니다.
const productList = {
backpack: 1200,
pencil: 800,
eraser: 600,
}
const productArray = Object.keys(productList).reduce((arr, key) => {
return [...arr, [key, productList[key]]]
/* 또는 이렇게
arr.push([key, productList[key]]);
return arr;
*/
}, [])
// [ [ 'backpack', 1200 ], [ 'pencil', 800 ], [ 'eraser', 600 ] ]
reduce
메서드를 사용해 비교적 쉽게 변환할 수 있었지만, 더 쉬운 방법이 있습니다.Object.entries(대상 객체명)
은 해당 객체의 키와 값의 쌍을 배열을 반환해 리턴합니다.
const productList = {
backpack: 1200,
pencil: 800,
eraser: 600,
}
const productArray = Object.entries(productList)
// [ [ 'backpack', 1200 ], [ 'pencil', 800 ], [ 'eraser', 600 ] ]
배열을 객체로 변환하기
반대로 배열을 객체로 변환하는 것도 가능합니다.Object.fromEntries(대상 배열명)
은 [["키 1", "값 1"], ["키 2", "값 2"] ... ]
형태의 배열을 객체로 변환해 리턴합니다.
const productArray = [
['backpack', 1200],
['pencil', 800],
['eraser', 600],
]
Object.fromEntries(productArray) // { backpack: 1200, pencil: 800, eraser: 600 }
이를 사용해, 객체의 각 요소에 배열에 메서드를 적용해 간단하게 값을 조작하는 것이 가능합니다.
배열의 map 메서드를 사용해 각 키의 값을 2배 증가시키는 예시
const productList = {
backpack: 1200,
pencil: 800,
eraser: 600,
}
Object.fromEntries(Object.entries(productList).map(([key, price]) => [key, price * 2]))
// { backpack: 2400, pencil: 1600, eraser: 1200 }
반응형
'💬 언어 > Javascript' 카테고리의 다른 글
자바스크립트 메모리 누수 방지 기법 (0) | 2021.09.12 |
---|---|
얼어붙어라! - 객체 불변화하기 (0) | 2021.08.26 |
데이터 페칭 로직 우아하게 개선하기 (3) | 2021.06.14 |
너! 배열이 되어라! - Array.from() 메서드 사용하기 (1) | 2021.05.29 |
제너레이터 사용하기 - 지연 평가 (lazy evaluation) (0) | 2021.05.03 |
Comments
소소한 팁 : 광고를 눌러주시면, 제가 뮤지컬을 마음껏 보러다닐 수 있어요!
와!! 바로 눌러야겠네요! 😆