class Point{
}
class ColorPoint extends Point{
}
复制代码
上面代码定义了一个ColorPoint类,该类经过extends关键字,继承了Point类的全部属性和方法。可是因为没有部署任何代码,因此这两个类彻底同样,等于复制了一个Point类。下面,咱们在ColorPoint内部加上代码。javascript
class ColorPoint extends Point {
constructor(x, y, color) {
super(x, y); // 调用父类的constructor(x, y)
this.color = color;
}
toString() {
return this.color + ' ' + super.toString(); // 调用父类的toString()
}
}
复制代码
super
来调用父类的 constructorclass ColorPoint extends Point {
}
// 等同于
class ColorPoint extends Point {
constructor(...args) {
super(...args);
}
}
复制代码
super
关键字做为函数调用。es6 中,子类的构造函数必须执行一次 super(记住咱们能够不写 constructor 和 super ,函数会自动添加上,看👆的 case)class A {}
class B extends A {
constructor() {
super();
}
}
复制代码
注意,
super
虽然表明了父类A的构造函数,可是返回的是子类B的实例,即super
内部的this
指的是B
,所以super()
在这里至关于A.prototype.constructor.call(this)
。java
class A {
constructor() {
console.log(new.target.name);
}
}
class B extends A {
constructor() {
super();
}
}
new A() // A
new B() // B
复制代码
上面代码中,
new.target
指向当前正在执行的函数。能够看到,在super()
执行时,它指向的是子类B的构造函数,而不是父类A的构造函数。也就是说,super()
内部的this
指向的是B。es6
super
做为对象时,在普通方法中,指向父类的原型对象;在静态方法中,指向父类。class A {
p() {
return 2;
}
}
class B extends A {
constructor() {
super();
console.log(super.p()); // 2
}
}
let b = new B();
复制代码