자바스크립트에서 클래스란 객체를 생성하는 템플릿입니다. 클래스를 사용하면 비슷한 객체를 쉽게 여러 개 만들 수 있으며, 코드의 재사용성과 유지보수가 용이해집니다. ES6 이전에는 프로토타입 기반 상속을 사용했지만, ES6부터는 클래스 기반의 문법이 도입되어 객체 지향 프로그래밍이 더욱 명확하고 직관적으로 이루어지게 되었습니다.
자바스크립트에서 클래스는 객체 지향 프로그래밍을 구현하는 데 사용되는 구조입니다. 클래스는 데이터와 이 데이터를 조작하는 메서드를 캡슐화합니다. 자바스크립트의 클래스는 다음과 같은 특징들을 가지고 있습니다.
자바스크립트에서 클래스는 class 키워드를 사용하여 선언합니다. 클래스 이름은 대문자로 시작하는 것이 일반적인 관례입니다. 클래스 선언은 호이스팅(hoisting)되지 않으므로, 선언 전에 클래스를 사용할 수 없습니다.
class MyClass {
// 클래스 정의
}
JavaScript클래스 내부에는 constructor 메서드를 정의할 수 있습니다. 이 메서드는 클래스로부터 객체가 생성될 때 자동으로 호출되며, 객체의 초기 속성을 설정하는데 사용됩니다.
class MyClass {
constructor(value) {
this.property = value;
}
}
JavaScript클래스 안에서 메서드를 정의할 수 있습니다. 이 메서드들은 클래스의 인스턴스에 대한 작업을 수행하거나, 클래스 또는 인스턴스의 속성 값을 조작할 때 사용됩니다.
class MyClass {
constructor(value) {
this.property = value;
}
myMethod() {
return this.property;
}
}
JavaScript자바스크립트 클래스는 상속을 지원합니다. extends 키워드를 사용하여 다른 클래스를 상속받을 수 있으며, 이를 통해 부모 클래스의 속성과 메서드를 활용할 수 있습니다.
class ParentClass {
parentMethod() {
return '부모 메서드';
}
}
class ChildClass extends ParentClass {
childMethod() {
return '자식 메서드';
}
}
JavaScriptstatic 키워드를 사용하여 정적 메서드를 선언할 수 있습니다. 정적 메서드는 인스턴스가 아닌 클래스 자체에 바인딩됩니다. 인스턴스를 생성하지 않고도 호출할 수 있는 메서드입니다.
class MyClass {
static staticMethod() {
return '정적 메서드';
}
}
JavaScript자바스크립트 클래스는 캡슐화를 통해 객체의 데이터를 숨기고, 외부에서 직접 접근하는 것을 제한할 수 있습니다. 이는 일반적으로 private 키워드 또는 클로저를 사용하여 구현됩니다.
class MyClass {
#privateProperty;
constructor(value) {
this.#privateProperty = value;
}
getPrivateProperty() {
return this.#privateProperty;
}
}
JavaScript클래스의 메서드에서 클래스 자신의 인스턴스(this)를 반환함으로써, 메서드 체이닝을 구현할 수 있습니다. 이를 통해 여러 메서드 호출을 연쇄적으로 연결할 수 있습니다.
class MyClass {
setValue(value) {
this.property = value;
return this;
}
displayValue() {
console.log(this.property);
return this;
}
}
JavaScript자바스크립트 클래스에서는 다형성도 구현할 수 있습니다. 상속받은 클래스에서 부모 클래스의 메서드를 재정의(오버라이딩)하여, 다양한 형태의 객체에서 같은 인터페이스를 갖지만 다른 작업을 수행할 수 있도록 합니다.
class ParentClass {
display() {
return '부모 클래스의 display 메서드';
}
}
class ChildClass extends ParentClass {
display() {
return '자식 클래스에서 오버라이딩된 display 메서드';
}
}
JavaScript이 예제에서는 자동차를 나타내는 Car 클래스를 만들고, 다양한 기능을 구현해 볼 것입니다. Car 클래스는 기본적인 속성과 메서드를 가지며, 이를 확장하여 전기차를 나타내는 ElectricCar 클래스도 만들어보겠습니다.
class Car {
constructor(brand, model, year) {
this.brand = brand; // 브랜드
this.model = model; // 모델
this.year = year; // 제조년도
}
displayInfo() {
return `${this.year}년식 ${this.brand} ${this.model}`;
}
startEngine() {
return `${this.model}의 엔진이 켜졌습니다.`;
}
}
JavaScriptclass ElectricCar extends Car {
constructor(brand, model, year, batteryLife) {
super(brand, model, year); // 부모 클래스의 생성자 호출
this.batteryLife = batteryLife; // 배터리 수명
}
chargeBattery() {
return `${this.model}의 배터리를 충전합니다. 충전 시간: ${this.batteryLife}시간`;
}
startEngine() {
return `${this.model}의 전기 모터가 작동합니다.`;
}
}
JavaScriptlet myCar = new Car('Hyundai', 'Sonata', 2020);
console.log(myCar.displayInfo()); // "2020년식 Hyundai Sonata"
console.log(myCar.startEngine()); // "Sonata의 엔진이 켜졌습니다."
let myElectricCar = new ElectricCar('Tesla', 'Model 3', 2021, 24);
console.log(myElectricCar.displayInfo()); // "2021년식 Tesla Model 3"
console.log(myElectricCar.chargeBattery()); // "Model 3의 배터리를 충전합니다. 충전 시간: 24시간"
console.log(myElectricCar.startEngine()); // "Model 3의 전기 모터가 작동합니다."
JavaScript자바스크립트의 클래스(Class)는 객체 지향 프로그래밍(OOP)의 중요한 개념을 구현하는 데 필수적인 요소입니다. 이러한 클래스는 데이터와 함수를 하나의 단위로 묶어 관리함으로써, 코드의 재사용성과 유지보수성을 향상시킵니다. 특히 ES6 이후 도입된 클래스 기반 문법은 자바스크립트 프로그래밍을 더욱 직관적이고 효율적으로 만들어 줍니다.
클래스의 주요 특징으로는 생성자와 인스턴스화, 상속, 메서드, 정적 메서드와 속성, 캡슐화와 접근 제어자, 프로토타입 기반 상속, 메서드 체이닝, 그리고 다형성 등이 있습니다. 이러한 특징들을 적절히 활용함으로써, 복잡한 로직을 간결하고 명확하게 표현할 수 있으며, 다양한 프로그래밍 문제에 효과적으로 대응할 수 있습니다.
컴포넌트 스캔이란? 컴포넌트 스캔(Component Scan)은 스프링 프레임워크가 특정 패키지를 탐색하면서, 스캔 대상에 해당하는 클래스를 찾아…
스프링 빈이란? 스프링 빈(Spring Bean)은 스프링 IoC(Inversion of Control) 컨테이너가 관리하는 자바 객체를 의미합니다. 간단히…
스프링 컨테이너(Spring Container)란? 스프링 컨테이너는 스프링 프레임워크에서 가장 핵심적인 부분으로, IoC(Inversion of Control) 개념을 기반으로…
Queue란 무엇인가? Java에서 Queue는 데이터 구조의 일종으로, 데이터를 선입선출(FIFO, First-In-First-Out) 방식으로 처리합니다. 이 글에서는 Queue의…
Stack이란 무엇인가? Java에서 Stack은 자료구조의 한 종류로, 데이터를 순서대로 쌓아 올리는 형태로 운영됩니다. 컴퓨터 과학에서…
소개 자바에서 Map 인터페이스는 키(Key)와 값(Value)의 쌍을 저장하는 자료구조입니다. 이는 연관 배열이라고도 불리며, 각 키는…