JS/[책] 모던 자바스크립트 Deep Dive

18. 함수와 일급 객체

배워도끝이없네 2021. 9. 5. 19:52

1. 일급 객체

- 다음과 같은 조건을 만족하는 객체를 일급 객체라 한다.

  1. 무명의 리터럴로 생성할 수 있다. 즉 런타임에서 생성이 가능하다.
  2. 변수나 자료구조(객체,배열)에 저장할 수 있다.
  3. 함수의 매개변수에 전달할 수 있다.
  4. 함수의 반환값으로 사용할 수 있다.

- 함수가 일급 객체라는 것은 함수를 객체와 동일하게 사용할 수 있다는 의미이다.

 

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프로퍼티는 함수가 객체를 생성하는 생성자 함수로 호출될 때 생성자 함수가 생성할 인스턴스의 프로토타입 객체를 가리킨다.