study: javascript | 숨참고 deep dive (16) 프로퍼티 어트리뷰트 - 220217

Lumpen·2023년 2월 22일
0

Javascript

목록 보기
3/4

내부 슬롯과 내부 메서드

자바스크립트 엔진의 구현 알고리즘을 설명하는 ECMAScript 사양에서의
수도 프로퍼티와 수도 메서드
자바스크립트 엔진에서 실제 동작하지만 사용자는 접근하거나 호출할 수 없다
일부 내부 슬롯과 메서드에는 접근 가능하다
내부슬롯 [[prototype]] 은 모든 객체가 가지고 있고
직접 접근은 불가능하지만 proto 를 통해 간접 접근이 가능하다

프로퍼티 어트리뷰트와 프로퍼티 티스크립터 객체

자바스크립트 엔진은 프로퍼티 생성 시 프로퍼티의 상태를 나타내는
프로퍼티 어트리뷰트를 기본 값으로 자동 정의한다
프로퍼티의 상태란 프로퍼티의
값, 값의 갱신 가능 여부, 열거 가능 여부, 재정의 가능 여부 등이다
프로퍼티 어트리뷰트는 자바스크립트 엔진이 관리하는 내부 상태 값인
내부 슬롯이다 따라서 직접 접근할 수 없지만
Object.getOwnPropertyDescriptor() 메서드를 통해 간접 확인 가능

Object.getOwnPropertyDescriptor() 메서드를 호출할 때
첫 번째 매개변수에는 객체의 참조를 전달하고
두 번째 매개변수에는 프로퍼티 키를 문자열로 전달한다
이 때 Object.getOwnPropertyDescriptor() 메서드는
프로퍼티 어트리뷰트 정보를 제공하는 프로퍼티 디스크립터 객체를 반환한다
존재하지 않는 프로퍼티나 상속 받은 프로퍼티에 대한 프로퍼티 디스크립터를 요구하면
undefined 가 반환된다

Object.getOwnPropertyDescriptor() 메서드는 하나의 프로퍼티에 대해
디스크립터 객체를 반환하지만 ES8 에서 도입된
Object.getOwnPropertyDescriptors() 메서드는
모든 프로퍼티의 프로퍼티 어트리뷰트를 제공하는 프로퍼티 디스크립터 객체들을 반환한다

데이터 프로퍼티와 접근자 프로퍼티

프로퍼티는 데이터 프로퍼티와 접근자 프로퍼티로 구분할 수 있다

데이터 프로퍼티: 키-값 형태의 일반적 프로퍼티
접근자 프로퍼티: 자체적으로 값을 갖진 않고 데이터 프로퍼티의 값을 읽거나 저장 시 호출되는 접근자 함수로 구성된 프로퍼티
데이터 프로퍼티는 다음과 같은 프로퍼티 어트리뷰트를 갖는다
프로퍼티 어트리뷰트는 자바스크립트 엔진이 프로퍼티를 생성할 때 기본 값으로 자동 정의된다

데이터 프로퍼티

[[Value]], [[Writerble]], [[Enumerable]], [[Configurable]]
각각 값, 변경 가능 여부, 열거 가능 여부, 재정의 가능 여부를 갖는
프로퍼티 어트리뷰트
프로퍼티 디스크립트 객체의 프로퍼티는 대괄호 제외한 이름

접근자 프로퍼티

접근자 프러퍼티는 자체 값을 갖진 않고 다른 데이터 프로퍼티의 값을 읽거나 저장할 때 사용하는 접근자 함수로 구성된 프로퍼티

접근자 프로퍼티는 get, set, enumerable, configurable 로
getter와 setter 를 제외하곤 데이터 프로퍼티와 같음

profile
떠돌이 생활을 하는. 실업자는 아니지만, 부랑 생활을 하는

0개의 댓글