Frontend/JavaScript

9. 클래스

예린lynn 2024. 7. 15. 02:33
728x90

 

추상화

추상화는 프로그램에 필요한 요소만 사용해서 객체를 표현하는 것이다. 

예를 들어, 병원에서 사용하는 프로그램을 만들 때 의사, 간호사, 환자, 병실 등의 필요한 정보를 추려내는 것이다.

 

 

생성자

생성자는 클래스를 기반으로 인스턴스를 생성할 때 처음 호출되는 메소드이다.

생성자에서는 속성을 추가하는 등 객체의 초기화 처리를 한다.

//기본형
 class 클래스 이름 {
   constructor () {
    /* 생성자 코드 */
   }
 }
 
 //예시
 class Student {
   constructor(이름, 국어, 영어){
     this.이름 = 이름
     this.국어 = 국어
     this.영어 = 영어
   }
 }

 

 

메소드 선언

//예시
getSum(){
  return this.국어 + this.영어
}

getAverage(){
  return this.getSum()/2
}

toString(){
  return '${this.이름}\t${this.getSum()}점\t${this.getAverage()}점\n'
}

const students = []
students.push(new Student('lynn',90,98))

 

 

상속

  • 상속은 extends 메서드를 이용해서 부모 클래스의 속성을 자식 클래스가 물려받아 사용할 수 있도록 한다.
  • 자식 클래스에서 속성을 추가할 때, constructor 재정의가 필요하다.
  • super() : 부모의 생성자 함수 호출
  • super. : 부모의 메소드에 접근
class Person {
  constructor(name, age){
    this.name = name;
    this.age = age;
  }
  introduce() {
    return 'My name is ${this.name}';
  }
}

class People extends Person{
  constructor(name, age, gender){
    super(name, age);
    this.gender = gender;
  }
  
 intro(){
   return super.introduce() + My sex is ${this.gender};
 }
}

 

 

728x90