[JavaScript] 모던 자바스크립트 Deep Dive 22장 - this
2022. 8. 4. 19:35ㆍWeb/JavaScript

this 키워드
this는 자신이 속한 객체 또는 자신이 생성할 인스턴스를 가리키는 자기 참조 변수다.
this를 통해 자신이 속한 객체 또는 자신이 생성할 인스턴스의 프로퍼티나 메서드를 참조할 수 있다.
this 바인딩은 함수 호출 방식에 의해 동적으로 결정된다.
함수 호출 방식과 this 바인딩
함수 호출 방식
- 일반 함수 호출
- 메서드 호출
- 생성자 함수 호출
- Function.prototype.apply/call/bind 메서드에 의한 간접 호출
일반 함수 호출
기본적으로 this에는 전역 객체가 바인딩된다.
function foo(){
console.log("foo is this: ", this); // window
function bar(){
console.log("bar is this: ", this); // window
}
bar();
}
foo();
메서드 호출
메서드 내부의 this에는 메서드를 호출한 객체, 즉 메서드를 호출할 때 메서드 이름 앞의 마침표(.) 연산자 앞에 기술한 객체가 바인딩된다.
const person = {
name: "Lee",
getName(){
// 메서드 내부의 this는 메서드를 호출한 객체에 바인딩된다.
return this.name;
}
};
// 메서드 getName을 호출한 객체는 person이다.
console.log(person.getName()); // Lee
생성자 함수 호출
생성자 함수 내부의 this에는 생성자 함수가 (미래에) 생성할 인스턴스가 바인딩된다.
// 생성자 함수
function Circle(radius){
// 생성자 함수 내부의 this는 생성자 함수가 생성할 인스턴스를 가리킨다.
this.radius = radius;
this.getDiameter = function(){
return 2 * this.radius;
};
}
const circle1 = new Circle(5);
const circle2 = new Circle(10);
console.log(circle1.getDiameter()); // 10
console.log(circle2.getDiameter()); // 20
Function.prototype.apply/ call/ bind 메서드에 의한 간접 호출
apply, call, bind 메서드는 Function.prototype의 메서드다. 즉, 이들 메서드는 모든 함수가 상속받아 사용할 수 있다.
function getThisBinding(){
return this;
}
// this로 사용할 객체
const thisArg = { a: 1 };
console.log(getThisBinding()); // window
// getThisBinding 함수를 호출하면서 인수로 전달한 객체를 getThisBinding 함수의 this에 바인딩한다.
console.log(getThisBinding.apply(thisArg)); // { a: 1 }
console.log(getThisBinding.call(thisArg)); // { a: 1 }
// bind 메서드는 첫 번째 인수로 전달한 this 바인딩이 교체된
// getThisBinding 함수를 새롭게 생성해 반환한다.
console.log(getThisBinding.bind(thisArg)); // [Function: bound getThisBinding]
console.log(getThisBinding.bind(thisArg)()); // { a: 1 }
'Web > JavaScript' 카테고리의 다른 글
| [JavaScript] 모던 자바스크립트 Deep Dive 24장 - 클로저 (0) | 2022.08.08 |
|---|---|
| [JavaScript] 모던 자바스크립트 Deep Dive 23장 - 실행 컨텍스트 (0) | 2022.08.04 |
| [JavaScript] 모던 자바스크립트 Deep Dive 21장 - 빌트인 객체 (0) | 2022.07.29 |
| [JavaScript] 모던 자바스크립트 Deep Dive 20장 - strict mode (0) | 2022.07.29 |
| [JavaScript] 모던 자바스크립트 Deep Dive 19장 - 프로토타입 (0) | 2022.07.28 |