推薦答案
super關鍵字是ES6新增的關鍵字,用于在子類中調用父類的構造函數和成員方法。在ES6之前,JavaScript中的繼承通常是通過原型鏈實現的,這種繼承方式的缺點是在子類中無法直接訪問父類的構造函數和成員方法。
使用super關鍵字可以輕松實現在子類中調用父類的構造函數和成員方法。super關鍵字用于指代當前對象所繼承的父對象,通過super關鍵字可以訪問父類的成員。
具體來說,super可以做兩件事情:
1. 調用父類構造函數:使用super()可以在子類中調用父類的構造函數,并傳遞參數。例如:
class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
}
class Student extends Person {
constructor(name, age, grade) {
super(name, age); // 調用父類構造函數
this.grade = grade;
}
}
let student = new Student("Tom", 18, "A");
在上面的代碼中,子類Student通過調用super(name, age)方法來調用父類Person的構造函數,以實現繼承父類的成員變量name和age。
2. 調用父類成員方法:使用super.methodName()可以在子類中調用父類的成員方法。例如:
class Person {
hello() {
console.log(`Hello, ${this.name}`);
}
}
class Student extends Person {
hello() {
super.hello(); // 調用父類方法
console.log(`I am a student of grade ${this.grade}`);
}
}
let student = new Student("Tom", 18, "A");
student.hello();
在上面的代碼中,子類Student通過調用super.hello()方法來調用父類Person的成員方法hello(),以實現繼承父類的行為。在子類中可以重寫父類的成員方法,并通過使用super關鍵字來調用父類的成員方法,從而實現擴展或重用父類的代碼。
其他答案
-
在ES6中,關鍵字super常常被用來引用父類的構造函數或方法。它允許我們在子類中訪問和調用父類的屬性和方法,從而使得代碼更加靈活和模塊化。在ES5中,我們通常通過在子類的構造函數中調用父類的構造函數來繼承父類的屬性和方法。例如,如果我們要創建一個Animal類和一個Dog類,使得Dog類繼承Animal類的屬性和方法,我們可以在Dog類的構造函數中調用Animal類的構造函數。這樣做雖然有效,但是存在重復的代碼和構造函數的綁定問題。ES6的關鍵字super就可以解決這些問題。
-
在ES6中,`super` 關鍵字用于訪問和調用父類的屬性和方法。它的主要作用是在子類中引用父類的構造函數和成員,以實現繼承和重用。具體理解 `super` 關鍵字有以下幾點:1. 調用父類構造函數:在子類的構造函數中,使用 `super()` 來調用父類的構造函數。這樣可以繼承父類的屬性和方法,并且可以在子類構造函數中添加自己的邏輯。2. 訪問父類的方法:通過 `super.method()` 的方式可以調用父類中的方法。這在子類中重寫父類方法時特別有用,可以在子類中調用父類的方法來實現父類的功能,并在此基礎上添加額外的操作。3. 訪問父類的屬性:使用 `super.property` 可以訪問父類的屬性。如果子類中沒有同名的屬性,可以通過 `super.property` 來獲取父類的屬性值。