当前位置:首页 > 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 也可以用于调用父类的方法,尤其是在子类中重写父类方法时。

js 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 方法。

js super 实现

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 中主要用于:

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

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

标签: jssuper
分享给朋友:

相关文章

js实现延迟

js实现延迟

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

js类实现

js类实现

使用类实现 JavaScript 功能 在 JavaScript 中,类(Class)是一种语法糖,基于原型继承机制。通过 class 关键字可以更直观地定义对象模板。 基本类定义 class…

js手势实现

js手势实现

手势识别实现方法 在JavaScript中实现手势识别通常涉及监听触摸事件(touchstart、touchmove、touchend)或鼠标事件(mousedown、mousemove、mouseu…

js实现求导

js实现求导

实现数值求导的方法 在JavaScript中实现求导通常采用数值方法,因为JavaScript不是符号计算语言。以下是常见的数值微分方法: 中心差分法 中心差分法提供较高精度的导数近似:…

js实现授权

js实现授权

授权流程设计 授权流程通常涉及前端与后端的交互,常见方案包括OAuth2.0、JWT等。以JWT为例的典型流程: 用户提交凭证(如用户名密码)到认证服务 服务端验证通过后生成包含用户信息的J…

js实现密码

js实现密码

密码强度验证 使用正则表达式验证密码强度是一种常见方法。以下代码检查密码是否包含大小写字母、数字和特殊字符,且长度至少为8位: function checkPasswordStrength(pass…