객체 리터럴

GY·2021년 11월 2일
0

[JS] 개념 정리

목록 보기
26/32
post-thumbnail

객체란?

자바스크립트는 객체 기반의 프로그래밍 언어이다.
자바스크립트를 구성하는 거의 모든 것이 객체다. (원시 값 제외)

객체는

  • 다양한 타입의 값을 하나의 단위로 구성한 복합적인 자료구조
  • 변경가능한 값
  • 0개 이상의 프로퍼티로 구성된 집합
    - 프로퍼티는 key와 value으로 구성된다.
  • 프로퍼티와 메서드로 구성된 집합체(하나의 단위로 구조화)
    - 프로퍼티: 객체의 상태를 나타내는 값
    • 메서드: 프로퍼티를 참조하고 상태를 조작할 수 있는 동작

객체 생성방식

객체 리터럴

자바스크립트는 프로토타입 기반 객체지향 언어로서 다양한 객체 생성 방법을 지원한다.

  • 객체 리터럴
  • Object 생성자 함수
  • 생성자 함수
  • Object.create 메서드
  • 클래스

리터럴 literal

사람이 이해할 수 있는 문자 또는 약속된 기호를 사용하여 값을 생성하는 표기법

정의 방법

  • 중괄호 {}내에 프로퍼티를 정의한다.
  • 변수에 할당되는 시점에 자바스크립트 엔진은 객체 리터럴을 해석해 객체를 생성한다.

객체 리터럴 방식은 단 하나의 객체만 생성한다.
따라서 동일한 프로퍼티를 갖는 객체를 여러 개 생성해야 하는 경우 매번 같은 프로퍼티를 기술해야하기 때문에 비효율적이다.

Object 생성자 함수

const person = new Object();

person.name = 'Lee';

console.log(person) //{name: "Lee"}

생성자 함수란?

new 연산자와 함께 호출하여 인스턴스를 생성하는 함수
인스턴스 : 생성자 함수에 의해 객체

객체를 생성하는 방식은 객체 리터럴을 사용하는 것이 더 간편하다.

생성자 함수

생성자 함수에 의한 객체 생성 방식은 프로퍼티 구조가 동일한 객체 여러 개를 간편하게 생성할 수 있다.

생성자 함수의 인스턴스 생성 과정

생성자 함수의 역할은 다음과 같다.

  • 프로퍼티 구조가 동일한 인스턴스를 생성하기 위한 템플릿으로서 동작하여
  • 인스턴스를 생성하고
  • [옵션] 생성된 인스턴스를 초기화(인스턴스 프로퍼티 추가 및 초기값 할당)

1. 인스턴스 생성과 this 바인딩

암묵적으로 빈 객체가 생성된다. (인스턴스)
이 인스턴스는 this에 바인딩되어 생성자 함수 내부의 this는 생성자 함수가 생성할 함수를 가리킨다.

2. 인스턴스 초기화

생성자 함수에 기술되어 있는 코드가 한 줄씩 실행되어 this에 바인딩되어 있는 인스턴스를 초기화한다.
즉, this에 바인딩되어 있는 인스턴스에 프로퍼티나 메서드를 추가하고 생성자 함수가 인수로 전달받은 초기값을 인스턴스 프로퍼티에 할당하여 초기화하거나 고정값을 할당한다.

3. 인스턴스 반환

생성자 함수 내부의 모든 처리가 끝나면 완성된 인스턴스가 바인딩된 this가 암묵적으로 반환된다.

profile
Why?에서 시작해 How를 찾는 과정을 좋아합니다. 그 고민과 성장의 과정을 꾸준히 기록하고자 합니다.

0개의 댓글