搜尋

首頁  >  問答  >  主體

javascript - ES6中class與super的疑惑

class Book{
            constructor(book1,book2) {
                this.book1 = book1;
                this.book2 = book2;
            }
            getName() {
                alert(this.book1+this.book2)
            }
        }
        class book extends Book{
            constructor() {
                super(book1,book2);
            }
            toSay() {
                super.getName();
            }
        }
        var cp = new book("javascript guide","javascript best pattern");

#看了阮一峰的ES6教程,對於class 和super還是有點疑惑,先建立一個Book類別
然後建立一個子類別book繼承父類別Book,super呼叫父類別的建構函數,在toSay中調用父類別的getName()方法,瀏覽器報錯

以下是阮一峰有關class的例子,程式碼結構只是比我多在子類別上定義一個color屬性,如果我的子類別不需要自己的屬性,完全呼叫父類別的屬性和方法,不行嗎?

class Point {
          constructor(x, y) {
            this.x = x;
            this.y = y;
          }

          toString() {
            return '(' + this.x + ', ' + this.y + ')';
          }
     }
         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()在子類別中是必須定義的


可是我的程式碼並沒有super,瀏覽器執行了


#請問這是為什麼?

黄舟黄舟2804 天前789

全部回覆(2)我來回復

  • 世界只因有你

    世界只因有你2017-05-19 10:33:04

    可以,子的book沒有傳參數

            class book extends Book{
                constructor(book1, book2) {
                    super(book1, book2);
                }
                toSay() {
                    super.getName();
                }
            }

    回覆
    0
  • ringa_lee

    ringa_lee2017-05-19 10:33:04

    樓上正解。
    如阮一峰老師所說:

    • 第一種情況,super當函式呼叫時,代表父類別的建構子。

    • 第二種情況,super作為物件時,在普通方法中,指向父類別的原型物件;在靜態方法中,指向父類別。

    回覆
    0
  • 取消回覆