본문 바로가기
Javascript

JavaScript - object(3)

by Su1993 2020. 7. 5.
반응형

객체의 키를 변수로 접근하기

 

Object(2)에서의 방법으로 사용하면 객체의 특정 키의 값을 가져오는 것도 가능하지만, 반대로 객체에 특정 키를 만들고 값을 할당하는 것도 가능하다.

 

information이라는 객체 하나를 만들어 예를 들자면,

 

const information = {
  name: '김개발'
}

 

여기에 키 하나를 생성하고, 그 키에 값을 할당해주려 한다.

 

const verb = 'developes'
const project = 'facebook'

 

verb의 값을 키로 사용해야 하고, project 값을 그 키의 값으로 사용한다고 했을 때,

 

information[verb] = project // [A]
information.developes = 'facebook' // [B]

 

A와 같이 할당이 가능하다. B의 방식으로도 할당이 가능할 수도 있겠지만, 이 경우 키와 값은 항상 정해져 있게 된다.

하지만 A와 같은 방법은 변수 verb와 project가 가지는 값에 따라 다른 키와 다른 값을 가지는 게 가능해진다.

 


객체 순회하기

 

객체도 배열처럼 순회가 가능하다. 다만 배열과 다르게 명확하게 정해진 순서가 없기 때문에, 어떤 순서에 따라 객체의 키에 접근하게 될지 알 순 없다. 때문에 객체의 순회는 "순서가 보장되지 않은 순회"라고 부른다.

배열을 순회할 때는 다음과 같이 for문을 사용했다.

 

const arr = ['coconut', 'banana', 'pepper', 'coriander']
for (let i = 0; i < arr.length; i++) {
  console.log(arr[i])
}

 

이런 반복문은 배열이 length 라는 키를 가지고 있고, 인덱스를 통해 각 배열 요소에 접근할 수 있었기 때문이다.

객체는 length 키가 따로 주어져있지 않고, 인덱스도 없기 때문에 이런식의 반복문은 불가능하다. 대신 크게 두 가지 방법으로 객체의 반복문 작성이 가능하다.

 

1. Object.keys()

Object.keys 메소드는 어떤 객체가 가지고 있는 키들의 목록을 배열로 리턴하는 메서드이다. 객체의 내장 메서드가 아니라 객체 생성자인 Object가 직접 가지고 있는 메서드이다. 사용법은 아래와 같다.

 

const obj = {
  name: 'melon',
  weight: 4350,
  price: 16500,
  isFresh: true
}

Object.keys(obj) // ['name', 'weight', 'price', 'isFresh']

 

Object.keys 메소드가 리턴하는 값은 배열이기 때문에 이걸로 우리가 반복문을 사용할 수 있다.

 

const keys = Object.keys(obj) // ['name', 'weight', 'price', 'isFresh']

for (let i = 0; i < keys.length; i++) {
  const key = keys[i] // 각각의 키
  const value = obj[key] // 각각의 키에 해당하는 각각의 값

  console.log(value)
}

 

새로운 ES6 문법에서는 Object.keys 외에도 마찬가지로 Object생성자의 메서드인 Object.values, Object.entries와 같은 자매품들이 추가되었다. Object.values는 객체의 키가 아닌 값으로 이루어진 배열을 리턴한다.

Object.entries는 객체의 키와 값의 쌍으로 이루어진 길이 2짜리 배열을 리턴한다. 각 배열에서 인덱스[0]의 값은 각각의 키를, 인덱스[1]의 값은 해당 키에 해당하는 값을 가지게 된다.

 

const values = Object.values(obj)
// values === ['melon', 4350, 16500, true]

const entries = Object.entries(obj)

/*
entries === [
  ['name', 'melon'],
  ['weight', 4350],
  ['price', 16500],
  ['isFresh', true]
]
*/

 

Object.entries가 조금 복잡해보이긴 하지만, Object.keys, Object.values, Object.entries 세 가지 중에서 제일 유용하게 쓰인다.

 

 

2. for-in

객체를 순회하는 두 번째 방법은 for-in문이다. 반복문인 for문과 같은 종류의 문법이지만, 객체와 배열을 위해 특별히 존재하는, ES6에서 추가된 문법이다. 이건 객체 순회 외에도, 일반적인 배열을 순회할 때도 아주 유용할 수 있다.

 

const arr = ['coconut', 'banana', 'pepper', 'coriander']

for (let i = 0; i < arr.length; i ++) {
  console.log(i)
  console.log(arr[i])
} 

 

이 예를 든 코드를 for-in으로 간단히 축약한다면 아래와 같다.

 

for (let i in arr) {
  console.log(i)
  console.log(arr[i])
}

 

i를 0으로 초기화하고, 배열의 길이와 비교하고, i를 1씩 증가시키는 등의 코드를 생략할 수 있게 만든 ES6문법이다.

이 for-in문은 인덱스의 값으로 무엇을 할당하고, 반복문이 몇 번 돌아야 할지를 자바스크립트 엔진 내부에서 자동으로 결정하게 된다.

for-in문은 배열뿐 아니라 객체에서도 작동하게 만들어졌다.

 

const obj = {
  name: 'melon',
  weight: 4350,
  price: 16500,
  isFresh: true
}

for (let key in obj) {
  const value = obj[key]

  console.log(key)
  console.log(value)
}

 

이렇게 객체를 가지고 for-in 문을 사용하면, for-in문의 인덱스에 해당하는 변수가, 숫자가 아닌 객체의 각각의 키에 해당하는 문자열을 할당받게 된다.

반응형

'Javascript' 카테고리의 다른 글

JavaScript - JSON  (0) 2020.09.02
JavaScript - script async와 defer  (0) 2020.08.24
JavaScript - array methods  (0) 2020.07.05
JavaScript - template literals, string method  (0) 2020.07.05
JavaScript - arrow function  (0) 2020.07.05

댓글