javascript-扩展类时使用super()的区别

前端之家收集整理的这篇文章主要介绍了javascript-扩展类时使用super()的区别 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在学习有关创建新类,扩展它和子类化的知识.我不了解以下内容

>为什么在示例2中扩展类时,constructor()和super()都使用length作为参数?
>如果示例2中的super()应该访问父类Polygon,那么它不应该使用高度和宽度作为参数来访问Polygon类中的父类而不是长度(就像示例4中那样)吗?如果没有,为什么?

代码是:https://googlechrome.github.io/samples/classes-es6/index.html

// Example 1: Creating a new class (declaration-form)
// ===============================================================

class Polygon {
  constructor(height,width) {
    this.name = 'Polygon';
    this.height = height;
    this.width = width;
  }
  sayName() {
    console.log('Hi,I am a ',this.name + '.');
  }

  sayHistory() {
    console.log('"Polygon" is derived from the Greek polus (many) ' +
      'and gonia (angle).');
  }
}


// Example 2: Extending an existing class
// ===============================================================

class Square extends Polygon {
  constructor(length) {
    super(length,length);
    this.name = 'Square';
  }
  get area() {
    return this.height * this.width;
  }
  set area(value) {
    this.area = value;
  }
}

let s = new Square(5);

s.sayName();
console.log('The area of this square is ' + s.area);

// Example 4: Subclassing methods of a parent class
// ===============================================================

class Rectangle extends Polygon {
  constructor(height,width) {
    super(height,width);
    this.name = 'Rectangle';
  }
  sayName() {
    console.log('Sup! My name is ',this.name + '.');
    super.sayHistory();
  }
}

let r = new Rectangle(50,60);
r.sayName();
最佳答案
正方形仅接受一个参数是有意义的,即其边之一的长度.但是,如果Square是Polygon的类型,则此处的Polygon需要两个参数,即height和width.

如果实例化一个Square,则该Square需要调用super来运行Polygon构造函数,该构造函数需要两个参数,即height和width.在Square构造函数中,它们是相同的-长度变量,因此调用

super(length,length);

示例4有所不同,因为它是矩形,而不是正方形.矩形接受两个参数,即高度和宽度,就像多边形一样,因此Rectangle构造函数和Polygon构造函数都用(height,width)调用,而super调用反映了:

super(height,width);

猜你在找的JavaScript相关文章