new 연산자와 함께 Object 생성자 함수를 호출하면 빈 객체를 생성하여 반환한다.
const person = new Object();
person.name = 'Lee';
person.sayHello = function () {
console.log('Hi! My name is ' + this.name);
};
console.log(person); // {name: 'Lee', sayHello: f}
person.sayHello(); // Hi My name is Lee
생성자 함수란 new 연산자와 함께 호출하여 객체를 생성하는 함수를 말한다. 생성자 함수에 의해 만들어진 객체를 인스턴스라 한다.
객체 리터럴로 객체를 생성할 시 재사용하기 힘들다는 단점이 있다.
생성자 함수로 객체를 만들면, 동일한 프로퍼티를 가지는 객체를 여러 개 간편하게 생성할 수 있다.
일반 함수와 동일하게 함수를 정의하고, new 연산자와 함께 호출하면 그 함수는 생성자 함수로 동작한다.
function Circle(raidus) {
this.radius = radius;
this.getDiameter = function () {
return 2 * this.radius;
}
}
const circle1 = new Circle(5);
const circle2 = new Circle(10);
console.log(circle1); // Circle { radius:5, getDiameter: f }
console.log(circle2.getDiameter()); // 20
// 일반 함수로 호출
const circle3 = Circle(15);
// 일반 함수로 호출된 Circle은 반환문이 없어 암묵적 undefined를 반환한다.
console.log(circle3); // undefined
// 일반 함수로 호출된 Circle 내의 this는 전역 객체를 가리킨다.
console.log(radius); // 15
자바스크립트 엔진은 암묵적 처리를 통해 인스턴스를 생성하고 반환한다.
인스턴스 생성과 this 바인딩
암묵적으로 빈 객체가 생성된다. 이 빈 객체가 생성자 함수가 생성한 인스턴스다.
이 빈 객체는 this에 바인딩 된다.
특히, 이 처리는 런타임 이전에 실행된다.
인스턴스 초기화
this에 바인딩 되어 있는 인스턴스를 초기화 한다.
인스턴스에 프로퍼티나 메서드를 추가하고, 생성자 함수가 인수로 받은 값을 초기값으로 할당한다.
인스턴스 반환
생성자 함수 내부의 처리가 끝나면 바인딩된 this가 암묵적으로 반환된다.
명시적으로 반환 시 this 반환이 무시된다.
new.target
생성자 함수가 new 연산자 없이 호출되는 것을 방지하기 위해 ES6에서 지원하는 함수다.
new연산자와 함께 생성자 함수로 호출되면 함수 내부의 new.target은 함수 자신을 가리킨다.
(참고로, IE에서는 지원하지 않는다.)