1. 일급 객체
- 다음과 같은 조건을 만족하는 객체를 일급 객체라 한다.
- 무명의 리터럴로 생성할 수 있다. 즉 런타임에서 생성이 가능하다.
- 변수나 자료구조(객체,배열)에 저장할 수 있다.
- 함수의 매개변수에 전달할 수 있다.
- 함수의 반환값으로 사용할 수 있다.
- 함수가 일급 객체라는 것은 함수를 객체와 동일하게 사용할 수 있다는 의미이다.
2. 함수 객체의 프로퍼티
- 함수는 객체이기때문에 프로퍼티를 가질 수 있다.
- arguments, caller, length, name, prototype 프로퍼티는 모두 함수객체의 데이터 프로퍼티다.
- 하지만 __proto__는 접근자 프로퍼티이며, 함수 객체 고유의 프로퍼티가 아니라 Object.prototype객체의 프로퍼티를 상속받았다.
2.1 arguments 프로퍼티
- 함수객체의 arguments 프로퍼티 값은 arguments 객체다.
- arguments객체는 함수 호출시 전달된 인수들의 정보를 담고있는 iterable 유사 배열 객체이며, 함수 내부에서 지역변수처럼 사용된다.
- 자바스크립트는 함수의 매개변수의 수와 인수의 개수가 일치하는지 확인하지 않는다.
- 함수의 매개변수는 함수 몸체 내부에서 변수와 동일하게 취급된다.
- 함수가 호출되면 함수 몸체 내에서 암묵적으로 매개변수가 선언된 후 undefined로 초기화된 이후 인수가 할당된다.
- 매개변수의 수를 초과한 인수는 버려지는 것이 아니라 arguments객체의 프로퍼티로 보관된다.
- arguments객체는 매개변수 개수를 확정할 수 없는 가변 인자 함수를 구현할 때 유용하다.
- arguments는 배열형태이지만 실제 배열이 아닌 유사 배열 객체이다.
- 유사 배열 객체는 length프로퍼티를 가진 객체로 for문으로 순회할 수 있는 객체를 의미한다.
- 유사 배열 객체는 배열 메서드를 사용할 경우 에러가 발생한다.
* arguments 객체의 Symbol (Symbol.iterator) 프로퍼티
- arguments객체의 Symbol 프로퍼티는 arguments객체를 이터러블하게 만들기 위한 프로퍼티이다.
2.2 caller 프로퍼티
- caller 프로퍼티는 ECMAScript 사양에 포함되지 않은 비표준 프로퍼티이다.
- 사용하지말자
2.3 length 프로퍼티
- length프로퍼티는 함수를 정의할 때 선언한 매개변수의 개수를 가리킨다.
2.4 name 프로퍼티
- 함수의 이름을 나타낸다.
- name프로퍼티는 ES5와 6에서 다르게 동작한다.
- 익명함수일 경우 ES5에서 name프로퍼티는 빈 문자열을 값으로 갖는다.
- ES6에서는 함수객체를 가리키는 식별자를 값으로 갖는다.
2.5 __proto__ 접근자 프로퍼티
- 모든 객체는 [[Prototype]] 이라는 내부 슬롯을 갖는다.
- [[Prototype]] 내부슬롯은 객체지향 프로그래밍의 상속을 구현하는 프로토타입 객체를 가리킨다.
- __proto__ 프로퍼티는 [[Prototype]] 내부슬롯이 가리키는 프로토타입 객체에 접근하기 위해 사용하는 접근자 프로퍼티이다.
- 직접 접근하지는 않고 간접적으로 프로토타입 객체에 접근할 수 있다.
* has OwnProperty 메서드
- 인수로 전달받은 프로퍼티 키가 객체 프고유의 프로퍼티 키인 경우에만 true를 반환하고, 상속받은 프로토타입의 프로퍼티 키인 경우 false를 반환한다.
2.6 prototype 프로퍼티
- prototype프로퍼티는 constructor만이 소유하는 프로퍼티이다.
- prototype프로퍼티는 함수가 객체를 생성하는 생성자 함수로 호출될 때 생성자 함수가 생성할 인스턴스의 프로토타입 객체를 가리킨다.
'JS > [책] 모던 자바스크립트 Deep Dive' 카테고리의 다른 글
20. strict mode (0) | 2021.09.07 |
---|---|
19. 프로토타입 (0) | 2021.09.06 |
17. 생성자 함수에 의한 객체 생성 (0) | 2021.09.05 |
16. 프로퍼티 어트리뷰트 (0) | 2021.08.30 |
15. let, const 키워드와 블록 레벨 스코프 (0) | 2021.08.30 |