기록/Modern JavaScript Deep Dive

18. 함수와 일급 객체

toppoo 2022. 11. 4. 20:03

일급 객체

  • 무명의 리터럴로 생성 가능 (런타임에 생성 가능)
  • 변수, 자료구조(객체/배열 등)에 저장 가능
  • 함수의 매개변수에 전달 가능
  • 함수의 반환값으로 사용 가능

 

// 1. 함수는 무명의 리터럴로 생성 가능
// 2. 함수는 변수에 저장 가능
// 런타임에 함수 리터럴이 평가되어 함수 객체가 생성되고 변수에 할당됨
const increase = function (num) {
  return ++num;
};

// 2. 함수는 객체에 저장 가능
const auxs = { increase };

// 3. 함수의 매개변수에 전달 가능
// 4. 함수의 반환값으로 사용 가능
function makeCounter(aux) {
  let num = 0;
  
  return function () {
    num = aux(num);
    return num;
  };
}

// 3. 함수는 매개변수에게 함수를 전달 가능
const increaser = makeCounter(auxs.increase);
console.log(increaser()); // 1
  • 자바스크립트의 함수는 위의 조건을 모두 만족하기 때문에 일급 객체임
  • 함수형 프로그래밍이 가능함

함수 객체의 프로퍼티

  • 데이터 프로퍼티
  • arguments
  • caller
  • length
  • name
  • prototype

 

__proto__

  • 접근자 프로퍼티
  • 함수 객체 고유의 프로퍼티가 아님
  • Object.prototype 객체의 프로퍼티를 상속받은 것
  • 모든 객체가 사용 가능

 

1. arguments 프로퍼티

  • 함수 객체의 arguments 프로퍼티 값 : arguments 객체
    • 함수 호출 시 전달된 인수를 프로퍼티 값으로 가짐
    • 프로퍼티 키는 인수의 순서를 나타냄
      • 인수 < 매개변수 시 나머지 매개변수는 undefined 로 초기화된 상태 유지
      • 인수 > 매개변수 시 나머지 인수는 무시됨
      • 모든 인수는 암묵적으로 arguments 객체의 프로퍼티로 보관됨
    • 순회 가능한 유사 배열 객체
    • 함수 내부에서 지역 변수처럼 사용됨
    • 함수 외부에서는 참조 불가능
    • callee 프로퍼티는 함수 자신을 가리킴
    • length 프로퍼티는 인수의 개수를 가리킴
    • 매개변수 개수를 확정할 수 없는 가변 인자 함수를 구현할 때 유용함

 

2. caller 프로퍼티

  • ECMAScript 사양에 포함되지 않은 비표준 프로퍼티
  • 이후 표준화될 예정이 없는 프로퍼티
  • 함수 자신을 호출한 함수를 가리킴

 

3. length 프로퍼티

  • 함수를 정의할 때 선언한 매개변수의 개수를 가리킴
  • arguments 객체의 프로퍼티 (인자 개수) 와 다를 수 있음

 

4. __proto__ 접근자 프로퍼티

  • [[Prototype]] 내부 슬롯이 가리키는 프로토타입 객체에 접근하기 위해서 사용하는 접근자 프로퍼티
  • 내부 슬롯에는 직접 접근 불가능
  • __proto__ 접근자 프로퍼티를 통해 간접적으로 프로토타입 객체에 접근 가능

 

5. prototype 프로퍼티

  • 생성자 함수로 호출할 수 있는 함수 객체인 constructor 만이 가지는 프로퍼티
  • 일반 객체와 non-constructor 에는 없음
  • 함수가 객체를 생성하는 생성자 함수로 호출될 때
    • 생성자 함수가 생성할 인스턴스의 프로토타입 객체를 가리킴