이번에는 1장 섹션 6 에서도 배웠던 비구조화 할당 문법을 잘 활용하는 방법에 대해서 알아보자
이전에 배웠던 것을 복습해보면, 비구조화 할당 문법을 사용하면 다음과 같이 객체 안에 있는 값을 추출해서 변수 혹은 상수로 바로 선언해 줄수 있었다.
const object = { a: 1, b: 2 };
const { a, b } = object;
console.log(a); // 1
console.log(b); // 2
그리고, 함수의 파라미터에서도 비구조화 할당을 할 수 있는 것도 배웠다.
const object = { a: 1, b: 2 };
function print({ a, b }) {
console.log(a);
console.log(b);
}
print(object);
그런데 여기서 만약 b값이 주어지지 않았다고 가정해 보자.
const object = { a: 1 };
function print({ a, b }) {
console.log(a);
console.log(b);
}
print(object);
// 1
// undefined
두번째 출력에서 undefined가 나타날 것이다.
비구조화 할당시 기본값 설정
이러한 상황에 b값에 기본 값을 주고 싶다면 이렇게 해줄수 있다.
const object = { a: 1 };
function print({ a, b = 2 }) {
console.log(a);
console.log(b);
}
print(object);
// 1
// 2
이는 꼭 함수의 파라미터에서만 할 수 있는 것은 아니다.
const object = { a: 1 };
const { a, b = 2 } = object;
console.log(a); // 1
console.log(b); // 2
비구조화 할당시 이름 바꾸기
이번에는 비구조화 할당을 하는 과정에서 선언 할 값의 이름을 바꾸는 방법을 알아보자.
예를 들어서 다음과 같은 코드가 있다고 가정해보자.
const animal = {
name: '멍멍이',
type: '개'
};
const nickname = animal.name;
console.log(nickname); // 멍멍이
위 코드에서는 animal.name값을 nickname값에 담고 있는데, 이름이 같다면 그냥 우리가 이전에 배웠던 대로 비구조화 할당을 쓰면 되는데 지금은 이름이 서로 다르다.
이러한 상황에서는 : 문자를 사용해서 이름을 바꿔줄수 있다.
const animal = {
name: '멍멍이',
type: '개'
};
const { name: nickname } = animal
console.log(nickname);
배열 비구조화 할당
비구조화 할당은 객체에만 할 수 있는 것이 아니다. 배열에서 할수 있다.
예시코드를 보자
const array = [1, 2];
const [one, two] = array;
console.log(one);
console.log(two);
이 문법은 배열 안에 있는 원소를 다른 이름으로 새로 선언해주고 싶을때 사용하면 매우 유용하다.
객체 비구조화 할당과 마찬가지로, 기본값 지정이 가능하다.
const array = [1];
const [one, two = 2] = array;
console.log(one);
console.log(two);
깊은 값 비구조화 할당
객체의 깊숙한 곳에 들어있는 값을 꺼내는 방법을 알아보자.
예를 들어서 다음과 같은 객체가 있다고 가정해보자.
const deepObject = {
state: {
information: {
name: 'velopert',
languages: ['korean', 'english', 'chinese']
}
},
value: 5
};
여기서 name, languages, value 값들을 밖으로 꺼내주고 싶다면 어떻게 해야 할까? 이럴땐 두가지 해결 방법이 있다. 첫번쨰는 비구조화 할당 문법을 두번 사용하는 것이다.
const deepObject = {
state: {
information: {
name: 'velopert',
languages: ['korean', 'english', 'chinese']
}
},
value: 5
};
const { name, languages } = deepObject.state.information;
const { value } = deepObject;
const extracted = {
name,
languages,
value
};
console.log(extracted); // {name: "velopert", languages: Array[3], value: 5}
const extracted = {
name,
languages,
value
}
이 코드는 다음과 같다
const extracted = {
name: name,
languages: languages,
value: value
}
만약에 key이름으로 선언된 값이 존재한다면, 바로 매칭시켜주는 문법이다. 이문법은 es6의 object-shorthand 문법이라고 부른다.
이번엔 두번째 방법, 한번에 모두 추출하는 방법을 알아 보겠다.
const deepObject = {
state: {
information: {
name: 'velopert',
languages: ['korean', 'english', 'chinese']
}
},
value: 5
};
const {
state: {
information: { name, languages }
},
value
} = deepObject;
const extracted = {
name,
languages,
value
};
console.log(extracted);
이렇게 하면 깊숙히 안에 들어있는 값도 객체에서 바로 추출 할 수 있답니다.

위 이미지에서 주황색으로 나타난 값들이 추출 된 것이다.
반면, 빨간색으로 나타난 값들은 따로 추출되지 않으니 참고!
'공부내용정리 > JavaScript' 카테고리의 다른 글
| 자바스크립트의 Scope에 대한 이해 (0) | 2021.04.27 |
|---|---|
| spread와 rest (0) | 2021.04.26 |
| 조건문 더 스마트 하게 쓰기 (0) | 2021.04.20 |
| 단축 평가(short-circuit evaluation)논리 계산법 (0) | 2021.04.20 |
| Truthy and Falsy (0) | 2021.04.19 |