[modern JS Deep Dive] - 18장 . 함수와 일급 객체

유선향·2025년 1월 18일
0

<modern_JS_Deep_Dive>

목록 보기
19/44

일급 객체

  • 무명의 리터럴로 생성할 수 있다. 즉, 런타임에 생성이 가능하다.
  • 변수나 자료구조에 저장할 수 있다.
  • 함수의 매개변수에 전달할 수 있다.
  • 함수의 반환값으로 사용할 수 있다.

자바스크립트의 함수는 위의 조건을 모두 만족하므로 일급 객체다

함수가 일급 객체라는 의미

  • 함수를 객체와 동일하게 사용할 수 있다는 의미
  • 객체는 값이므로 함수는 값과 동일하게 취급할 수 있다.
  • 일반 객체처럼 함수의 매개변수에 전달할수 있으며, 함수의 반환값으로 사용할 수도 있다는 것이다.

함수와 일반 객체의 차이

  • 일반 객체는 호출할수 없지만 함수는 호출할 수 있다.
  • 함수 객체는 일반 객체에는 없는 함수 고유의 프로퍼티를 소유한다.

함수 객체의 프로퍼티

함수는 객체이기에, 프로퍼티를 가질수 있다.

1. arguments 프로퍼티

  • 함수객체의 arguments 프로퍼티는 함수 내부에서 지역 변수처럼 사용된다.
    • ⇒ 함수 외부에서는 참조할 수 없다.
  • 매개변수 개수를 확정할 수 없는 가변 인자 함수를 구현할 때 유용하다.
  • 실제 배열이 아닌 유사 배열 객체다.
  • 유사배열 객체
    • length 프로퍼티를 가진 객체로 for 문으로 순회할 수 있는 객체
    • 배열이 아니므로 배열 메서드는 사용 불가하다
  • 참조할수 없는 한계점을 보완하기 위해 rest 파라미터를 도입했다.
function sum(...rest){
	...
}

2. length 프로퍼티

  • 함수 객체의 length 프로퍼티는 함수를 정의할 때 선언한 매개변수의 개수를 가리킨다.
    function sum(x,y){
    	...
    }
    console.log(sum.length) //2

3. name 프로퍼티

  • 함수 객체의 name 프로퍼티는 함수 이름을 나타낸다.
  • ES5에서는 익명 함수 표현식의 경우 name 프로퍼티는 빈 문자열이다.
  • ES6에서는 함수 객체를 가리키는 식별자를 값으로 갖는다.

4. __proto__ 접근자 프로퍼티

'19장. 프로토타입' 에 더 자세한 내용이 나와있다.

  • 모든 객체는 [[prototype]] 이라는 내부 슬롯을 갖는다.
  • 내부슬롯은 객체지향 프로그래밍의 상속을 구현하는 프로토타입 객체를 가리킨다.
  • 내부 슬롯에는 직접 접근할 수 없고 간접적인 접근 방법을 제공하는 경우에 한하여 접근할 수 있다.

5. prototype 프로퍼티

  • prototype 프로퍼티는 생성자 함수로 호출할 수 있는 함수 객체, 즉 constructor 만이 소유하는 프로퍼티다
  • 일반 객체와 생성자 함수로 호출할 수 없는 non-constructor에는 prototype 프로퍼티가 없다.

0개의 댓글