Baseline Widely available
La palabra clave extends es usada en la declaración o expresión de clases, para crear una clase hija de otra.
Sintaxisclass ChildClass extends ParentClass { ... }Descripción
La palabra clave extends
se puede usar para crear una subclase a partir de clases personalizadas, asà como sus objetos incorporados.
La propiedad .prototype
de la nueva subclase debe ser un Object
o null
.
extends
El primer ejemplo crea una clase con el nombre Square
a partir de una clase llamada Polygon
. Este ejemplo ha sido extraido del siguiente live demo (código fuente).
class Square extends Polygon {
constructor(length) {
// Aquà se invoca el constructor de la clase padre con longitud
// proporcionada por el ancho y alto de Polygon
super(length, length);
// Nota: En las clases extendidas, se debe llamar a super()
// antes de poder usar 'this'. El no hacerlo provocará un reference error.
this.name = "Square";
}
get area() {
return this.height * this.width;
}
set area(value) {
this.area = value;
}
}
Como usar extends
con objetos incorporados
Este ejemplo extiende el objeto incorporado Date
. Este ejemplo ha sido extraido del siguiente live demo (código fuente).
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()
);
}
}
Extendiendo de null
Extender de null
es como hacerlo de una clase normal, excepto que el objeto prototype no hereda de Object.prototype
.
class nullExtends extends null {
constructor() {}
}
Object.getPrototypeOf(nullExtends); // Function.prototype
Object.getPrototypeOf(nullExtends.prototype); // null
Especificaciones Compatibilidad con navegadores Ver también
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4