extends - JavaScript 编辑
extends
关键字用于类声明或者类表达式中,以创建一个类,该类是另一个类的子类。
语法
class ChildClass extends ParentClass { ... }
描述
extends
关键字用来创建一个普通类或者内建对象的子类。
继承的.prototype
必须是一个Object
或者 null
。
示例
使用 extends
第一个例子是根据名为 Polygon
类创建一个名为Square
的类。这个例子是从这个在线演示中提取出来的。
class Square extends Polygon {
constructor(length) {
// Here, it calls the parent class' constructor with lengths
// provided for the Polygon's width and height
super(length, length);
// Note: In derived classes, super() must be called before you
// can use 'this'. Leaving this out will cause a reference error.
this.name = 'Square';
}
get area() {
return this.height * this.width;
}
}
使用 extends与内置对象
这个示例继承了内置的Date
对象。这个例子是从这个在线演示中提取出来的。
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
,但是新对象的原型将不会继承 Object.prototype
。
class nullExtends extends null {
constructor() {}
}
Object.getPrototypeOf(nullExtends); // Function.prototype
Object.getPrototypeOf(nullExtends.prototype) // null
new nullExtends(); //ReferenceError: this is not defined
标准
Specification | Status | Comment |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) extends | Standard | Initial definition. |
ECMAScript (ECMA-262) extends | Living Standard |
浏览器兼容
BCD tables only load in the browser
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.扩展阅读
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论