[JavaScript]비구조화 할당 (구조 분해)문법

feelslikemmmm·2020년 11월 27일
0

javascript

목록 보기
34/37
post-thumbnail

비구조화 할당 (구조 분해)문법

비구조화 할당 문법을 사용하면 다음과 같이

객체 안에 있는 값을 추출해서 변수 혹은 상수로 바로 선언해 줄 수 있습니다

그리고, 함수의 파라미터에서도 비구조화 할당을 할 수 있습니다

그런데 여기서 만약 b 값이 주어지지 않았다고 가정해봅시다.

두번째 출력에서 undefined가 나타납니다

비구조화 할당시 기본값 설정

이러한 상황에 b 값에 기본 값을 주고 싶다면 이렇게 해줄 수 있습니다.

이것은 꼭 함수의 파라미터에서만 할 수 있는 것은 아닙니다.

비구조화 할당시 이름 바꾸기

이번에는, 비구조화 할당을 하는 과정에서 선언 할 값의 이름을 바꾸는 방법을 알아보겠습니다.

예를 들어서 다음과 같은 코드가 있다고 가정해봅시다.

위 코드에서는 food.name 값을 foodname 값에 담고 있는데

이름이 같다면 그냥 이전에 배웠던 대로 비구조화 할당을 쓰면 되는데 지금은 이름이 서로 다릅니다.

이러한 상황에서는 : 문자를 사용해서 이름을 바꿔줄 수 있습니다.

위 코드는 food 객체 안에 있는 name 을 foodname 이라고 선언하겠다. 라는 의미입니다.

배열 비구조화 할당

비구조화 할당은 객체에만 할 수 있는 것이 아닙니다. 배열에서 할 수 있어요.

예시 코드를 봅시다.

이 문법은 배열 안에 있는 원소를 다른 이름으로 새로 선언해주고 싶을 때 사용하면 매우 유용합니다.

객체 비구조화 할당과 마찬가지로, 기본값 지정이 가능합니다.

깊은 값 비구조화 할당

객체의 깊숙한 곳에 들어있는 값을 꺼내는 방법을 알아봅시다.

예를들어서 다음과 같은 객체가 있다고 가정해봅시다.

여기서, name, languages, value 값들을 밖으로 꺼내주고 싶다면 어떻게 해야 할까요?

이럴땐 두가지 해결 방법이 있는데요, 첫번째는 비구조화 할당 문법을 두번 사용하는 것입니다.

그런데 잠깐! 지금 extracted 객체를 선언 할 때 이런식으로 했는데요

const extracted = {
  name,
  languages,
  value
}

이 코드는 다음코드와 똑같습니다

const extracted = {
  name: name,
  languages: languages,
  value: value
}

만약에 key 이름으로 선언된 값이 존재하다면, 바로 매칭시켜주는 문법입니다.

이 문법은 ES6 의 object-shorthand 문법이라고 부릅니다.

deepObject 객체에서 names, languages, value 를 추출하는 과정에서 비구조화 할당을 두번 했었습니다

이번엔 두번째 방법, 한번에 모두 추출하는 방법을 알아보겠습니다.

이렇게 하면 깊숙히 안에 들어있는 값도 객체에서 바로 추출 할 수 있습니다

이 포스팅은 벨로퍼트님의 알아두면 유용한 자바스크립트 문법을 기반으로 작성되었습니다

profile
꾸준함을 잃지 말자는 모토를 가지고 개발하고 있습니다 :)

2개의 댓글

게시물 100개 넘은거...실허ㅏ에염? ㅋㅋㅋㅋㅋㅋ 열심히 하시네용 !! 앞으로도 화이팅 입니당
게시물 내용도 너무 좋습니다👍🏻

1개의 답글