본문 바로가기

programming study/JavaScript

22장 this

본 내용은 모던 자바스크립트 Deep Dive - 자바스크립트의 기본 개념과 동작 원리를 토대로 작성하였습니다.

 

22.1 this 키워드

  • 자신이 속한 객체 또는 자신이 생성할 인스턴스를 가리키는 특수한 식별자
    • 자기 참조 변수
  • 자바스크립트 엔진에 의해 암묵적으로 생성
  • 코드 어디서든 참조 가능
  • this 바인딩은 함수 호출 방식에 의해 동적으로 결정
  • 객체 리터럴의 경우
    • 메서드를 호출한 객체를 가리킴
  • 생성자 함수의 경우
    • 생성자 함수가 생성할 인스턴스를 가리킴
  • 함수가 호출되는 방식에 따라 this 바인딩이 동적으로 결정

22.2 함수 호출 방식과 this 바인딩

  • 함수 호출 방식에 따라 동적으로 결정
  • 일반 함수 호출
    • 전역 객체 window를 가리킴(콜백 함수, 중첩 함수)
    • strict mode일 때는 undefined
  • 메서드 호출
    • 메서드를 호출한 객체 obj를 가리킴
    • 다른 객체의 프로퍼티에 할당하여 다른 객체의 메서드가 될 수 있음
    • 일반 변수에 할당하여 일반 함수로 호출 가능
  • 생성자 함수 호출
    • 생성자 함수가 생성한 인스턴스를 가리킴

Function.prototype.apply/call/bind

  • 모든 함수가 상속받아 사용할 수 있는 메서드들
  • apply/call
    • 함수를 호출
    • 첫 번째 인수로 전달한 특정 객체를 호출한 함수의 this에 바인딩
    • apply는 두번째 인수로 호출할 함수의 인수를 배열로 전달
    • call은 두번째 인수부터 쉼표로 구분한 리스트 형식으로 전달
    • 유사 배열 객체에 배열 메서드를 사용하는 경우에 사용
  • bind
    • 함수를 호출하지 않음
    • 첫 번째 인수로 전달한 값으로 this 바인딩이 교체된 함수를 생성해 반환

'programming study > JavaScript' 카테고리의 다른 글

23장 실행 컨텍스트(2)  (0) 2022.03.24
23장 실행 컨텍스트(1)  (0) 2022.03.24
21장 빌트인 객체(2)  (0) 2022.03.21
21장 빌트인 객체(1)  (0) 2022.03.20
20장 strict mode(2)  (0) 2022.03.19