当前位置:首页 > JavaScript

js super 实现

2026-01-31 21:48:31JavaScript

super 在 JavaScript 中的实现

在 JavaScript 中,super 关键字用于调用父类的构造函数或方法。它主要用于类的继承场景中,确保子类能够正确访问父类的属性和方法。

调用父类构造函数

在子类的构造函数中,super() 必须在使用 this 之前调用,否则会抛出错误。这是因为 super() 负责初始化父类的 this 对象。

class Parent {
  constructor(name) {
    this.name = name;
  }
}

class Child extends Parent {
  constructor(name, age) {
    super(name); // 调用父类的构造函数
    this.age = age;
  }
}

const child = new Child('Alice', 10);
console.log(child.name); // 输出: Alice
console.log(child.age);  // 输出: 10

调用父类方法

super 也可以用于调用父类的方法,尤其是在子类中重写父类方法时。

class Parent {
  greet() {
    return 'Hello from Parent';
  }
}

class Child extends Parent {
  greet() {
    return super.greet() + ' and Hello from Child';
  }
}

const child = new Child();
console.log(child.greet()); // 输出: Hello from Parent and Hello from Child

静态方法中的 super

super 也可以在静态方法中使用,用于调用父类的静态方法。

class Parent {
  static greet() {
    return 'Hello from static Parent';
  }
}

class Child extends Parent {
  static greet() {
    return super.greet() + ' and Hello from static Child';
  }
}

console.log(Child.greet()); // 输出: Hello from static Parent and Hello from static Child

注意事项

  • 在子类的构造函数中,super() 必须在使用 this 之前调用。
  • 如果子类没有定义构造函数,JavaScript 会默认提供一个构造函数并自动调用 super()
  • super 只能在类的方法或构造函数中使用,不能在普通函数中使用。
class Parent {
  constructor() {
    this.name = 'Parent';
  }
}

class Child extends Parent {
  // 没有定义构造函数,JavaScript 会自动调用 super()
}

const child = new Child();
console.log(child.name); // 输出: Parent

super 的实现原理

super 的实现依赖于 JavaScript 的原型链。当调用 super.method() 时,JavaScript 会从当前对象的原型链上查找 method 方法。

class Parent {
  method() {
    return 'Parent method';
  }
}

class Child extends Parent {
  method() {
    return super.method();
  }
}

const child = new Child();
console.log(child.method()); // 输出: Parent method

箭头函数中的 super

箭头函数没有自己的 super,它会从外层作用域继承 super

class Parent {
  method() {
    return 'Parent method';
  }
}

class Child extends Parent {
  method() {
    const arrowFunc = () => super.method();
    return arrowFunc();
  }
}

const child = new Child();
console.log(child.method()); // 输出: Parent method

总结

super 在 JavaScript 中主要用于:

js super 实现

  • 调用父类的构造函数。
  • 调用父类的方法(包括静态方法)。
  • 确保子类能够正确继承父类的行为。

正确使用 super 是实现类继承的关键部分。

标签: jssuper
分享给朋友:

相关文章

js 实现vue

js 实现vue

Vue.js 的基本实现 在 JavaScript 中实现 Vue.js 的核心功能,可以通过数据绑定、响应式系统和虚拟 DOM 来实现。以下是实现 Vue.js 核心功能的简化版本。 数据响应式系…

js实现延迟

js实现延迟

实现延迟的方法 在JavaScript中,实现延迟操作有多种方式,以下是几种常见的方法: 使用setTimeout函数 setTimeout是JavaScript中最常用的延迟执行方法。它接受一个回…

js实现交换

js实现交换

交换变量的方法 在JavaScript中,交换两个变量的值有多种方法。以下是常见的几种实现方式: 使用临时变量 通过引入一个临时变量来存储其中一个变量的值,实现交换: let a = 1; le…

js 实现滚动

js 实现滚动

实现滚动的方法 使用 window.scrollTo() window.scrollTo() 方法可以滚动到文档中的特定位置。可以指定 x 和 y 坐标,或者使用平滑滚动的选项。 // 滚动到指定位…

js实现搜索

js实现搜索

实现搜索功能的方法 在JavaScript中实现搜索功能可以通过多种方式完成,以下是几种常见的实现方法。 使用数组的filter方法 通过数组的filter方法可以筛选出符合条件的数据项。假设有一个…

js 实现页面刷新

js 实现页面刷新

使用 location.reload() location.reload() 是原生 JavaScript 提供的页面刷新方法。调用该方法会重新加载当前页面,相当于点击浏览器的刷新按钮。 // 基本…