티스토리 뷰
new 생성자에 대해 이해하기
자바스크립트에서는 new라는 키워드를 통해 특정 함수로 객체를 만들어 낼 수 있습니다. 쉽게 설명하자면, 붕어빵 틀이 있으면 똑같은 형태의 붕어빵을 계속 찍어낼 수 있습니다. 속에 넣는 재료를 팥이나 생크림, 초콜렛을 넣는다고 하면 맛은 다양하지만 그래도 같은 틀에서 찍어냈으니 똑같은 형태를 가지고 있겠죠.
new 생성자는 생성자 함수(붕어빵 틀)로 객체 인스턴스(생크림 맛 붕어빵, 초코 맛 붕어빳)를 만듭니다.
생성자 함수 만들기
function Bread(flavor, price){ this.flavor = flavor; this.price = price; }; const chocoBread = new Bread("choco", "2200원"); const creamBread = new Bread("cream", "2100원");
예시를 보면서 더 설명해보겠습니다. 생성자 함수라도 일반적인 함수처럼 만드시면 됩니다. 하지만 식별자에 첫글자를 대문자로 해주세요. 보통 자바스크립트에서 식별자를 카멜케이스(소문자로 시작, 띄어쓰기가 필요한 부분마다 대문자)로 많이 나타내지만 생성자 함수라는 것을 다른 사람들이 쉽게 파악하게 하기 위해 생성자 함수는 식별자를 대문자로 시작합니다. 그리고 함수에 flavor와 price라는 매개변수가 있습니다. 함수 바디에서 할당연산자(=) 오른쪽에 있는 값들이 매개변수로 전달된 값이고, 할당연산자 왼쪽에 있는 this.flavor와 this.price는 만들어진 객체의 속성이 됩니다.
this는 만들어질 객체를 가리킨다고 생각하심 됩니다.
new 생성자를 통해서 크림맛과 초코맛 빵을 만들었습니다. 만들어진 객체의 속성을 확인해볼까요?
매개변수로 전달된 값들이 속성 값으로 들어가 있는 것을 확인할 수 있습니다.
상속에 관한 이해
Bread.prototype.isPrice = function(){ console.log(`price of ${this.flavor} bread is ${this.price} 입니다.`); };
위와 같이 정의하면 chocoBread.isPrice()나 creamBread.isPrice()를 이용해서 가격을 볼 수 있습니다.
__proto__와 prototype의 이해
chocoBread객체를 보면 __proto__라는 속성이 있습니다. 이것은 chocoBread가 어디서 상속을 받았는지를 알려줍니다. 함수 Bread로부터 받았다고 나와있죠. 그리고 또 __proto__가 있고 그 옆엔 Object라고 적혀있습니다. 자바스크립트는 모든 것이 객체로부터 시작했습니다. 프로토타입(원형)의 끝은 객체입니다. 객체로부터 만들어졌기 때문에 사실 함수도, 배열도, 기타등등도 모두 객체인 것입니다. prototype은 내 자식들에게 물려줄 것이라고 생각하면 됩니다. 그래서 isPrice()를 정의하고 메소드를 자식이 가져올 수 있었던 것입니다.
undefined를 반환한다는 것의 의미
'Frontend-dev > HTML-CSS-JS' 카테고리의 다른 글
자바스크립트의 스코프(var, let, const) (0) | 2018.02.24 |
---|---|
자바스크립트의 화살표 함수(arrow function) (0) | 2018.02.23 |
자바스크립트 함수 (0) | 2018.02.22 |
매개변수에 구조분해 활용 (0) | 2018.02.21 |
조건 연산자(삼항 연산자)와 if else문 (0) | 2018.02.19 |