A classe JavaScript se estende
Exemplo
Crie uma classe chamada "Model" que herdará os métodos da classe "Car":
class Car {
constructor(brand) {
this.carname =
brand;
}
present() {
return 'I have a ' + this.carname;
}
}
class Model extends Car {
constructor(brand, mod) {
super(brand);
this.model = mod;
}
show() {
return this.present() + ', it is a ' + this.model;
}
}
mycar = new Model("Ford", "Mustang");
document.getElementById("demo").innerHTML
= mycar.show();
Definição e uso
A extends
palavra-chave é usada para criar uma classe filha de outra classe (pai).
A classe filha herda todos os métodos de outra classe.
A herança é útil para reutilização de código: reutilize propriedades e métodos de uma classe existente ao criar uma nova classe.
Nota: Do exemplo acima; O super()
método se refere à classe pai. Ao chamar o super()
método no método construtor, chamamos o método construtor do pai e obtemos acesso às propriedades e métodos do pai.
Suporte ao navegador
extends
é um recurso ECMAScript6 (ES6).
O ES6 (JavaScript 2015) é compatível com todos os navegadores modernos:
Chrome | Edge | Firefox | Safari | Opera |
Yes | Yes | Yes | Yes | Yes |
extends
não é compatível com o Internet Explorer 11 (ou anterior).
Sintaxe
class childClass extends parentClass
Detalhes técnicos
Versão JavaScript: | ECMAScript 2015 (ES6) |
---|
Páginas relacionadas
Tutorial JavaScript: Classes JavaScript
Tutorial JavaScript: JavaScript ES6 (EcmaScript 2015)
Referência JavaScript: A super palavra-chave
Referência JavaScript: O método constructor()