JavaScript

JS - 생성자 함수

dev_SiWoo 2022. 4. 27. 13:00

- 객체 리터럴

let user = {

name : Mike,

age : 30,

}

 

Javascript에서는 위와 같이 name, age를 갖는 객체를 선언하여 만들어 줄 수 있다.

 

 그런데 개발을 하다보면 이러한 객체 리터럴을 여러개 생성해야하는 경우가 있는데

이럴 때 생성자 함수를 통해서 간편하게 생성할 수 있다.

function User(name, age) {
  this.name = name;
  this.age = age;
  this.sayName = function () {
    console.log(this.name);
  };
}

let user1 = new User("Kim", 20);
let user2 = new User("Han", 40);
let user3 = new User("Park", 30);
console.log(user1);
console.log(user3);
user2.sayName();

 

 

이러한 생성자 함수를 작성할 떄 관례적으로 첫글자를 대문자로 작성해준다.

 

- 생성자 함수의 동작원리

 위 이미지에서 보이는 것처럼 실제로는 this ={}와 return this를 작성하지는 않지만 

작성된 것처럼 동작한다.

 

따라서 new 를 통해서 생성자 함수를 사용하면  먼저 생성자함수내에서 this = {} 라는 빈객체를 만들고

name, age를 각각 할당해준다. 그다음 this를 리턴해준다.