extends
BaselineWidely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since March 2016.
시도해 보기
class DateFormatter extends Date { getFormattedDate() { const months = [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", ]; return `${this.getDate()}-${months[this.getMonth()]}-${this.getFullYear()}`; }}console.log(new DateFormatter("August 19, 1975 23:15:30").getFormattedDate());// Expected output: "19-Aug-1975"
구문
class ChildClass extends ParentClass { ... }
설명
예
extends
사용하기
첫 번째 예는Polygon
클래스로부터Square
클래스를 만듭니다. 이 예는live demo(source)에서 발췌했습니다.
js
class Square extends Polygon { constructor(length) { // 여기서, length와 함께 부모 클래스의 생성자를 호출 // Polygon의 너비 및 높이가 제공됨 super(length, length); // 주의: 파생 클래스에서, super()가 먼저 호출되어야 'this'를 // 사용할 수 있습니다. 이를 빼먹으면 참조 오류가 발생합니다. this.name = "Square"; } get area() { return this.height * this.width; } set area(value) { this.area = value; }}
내장 객체에extends
사용하기
이 예제는 내장 객체Date
를 확장합니다. 이 예제는live demo(source)에서 발췌했습니다.
js
class myDate extends Date { constructor() { super(); } getFormattedDate() { var months = [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", ]; return ( this.getDate() + "-" + months[this.getMonth()] + "-" + this.getFullYear() ); }}
null
확장
null
에서 확장은 prototype 객체가Object.prototype
으로부터 상속받지 않은 것을 제외하면 보통 클래스처럼 동작합니다.
js
class nullExtends extends null { constructor() {}}Object.getPrototypeOf(nullExtends); // Function.prototypeObject.getPrototypeOf(nullExtends.prototype); // null
명세서
Specification |
---|
ECMAScript® 2026 Language Specification # sec-class-definitions |