JS实现继承的方式ES6版

上一篇:JS实现继承的方式原生版

ES6的继承

主要是依赖extends关键字来实现继承,且继承的效果类似于寄生组合继承。

复制代码
class Parent() {
}

class Child extends Parent {
    constructor(x, y, color) {
        super(x, y);
        this.color = color;
    }
}

子类必须在constructor方法中调用super方法,否则新建实例时会报错。这是因为子类自己的this对象,必须先通过父类的构造函数完成塑造,得到与父类同样的实例属性和方法,然后再对其进行加工,加上子类自己的实例属性和方法。如果不调用super方法,子类就得不到this对象。

复制代码
class Parent {
    constructor() {}
}
​
class Child extends Parent {
    constructor() {
        this.num = 10//报错
        super()
        this.num = 10//正确写法
    }
    
}

没有 constructor 会被默认添加,相当于 constructor(...args) { super(...args) }

super

super的使用方式:

1、当函数使用。作为函数调用时,代表父类的构造函数。ES6 要求,子类的构造函数必须执行一次super函数。

super虽然代表了父类A的构造函数,但是返回的是子类B的实例,即super内部的this指的是B的实例,因此super()在这里相当于A.prototype.constructor.call(this)。

作为函数时,super()只能用在子类的构造函数之中,用在其他地方就会报错。

2、当对象使用。在普通方法中,指向父类的原型对象A.prototype;在静态方法中,指向父类。

复制代码
// 当函数使用
class A {}

class B extends A {
  constructor() {
    super();
  }
}

// 当对象使用,当对象使用时,相当于引用A原型上的方法。
class A {
  p() {
    return 2;
  }
}

class B extends A {
  constructor() {
    super();
    console.log(super.p()); // 2
  }
}

let b = new B();

prototype和__proto__

类中:

子类的__proto__指向父类

子类prototype属性的__proto__指向父类的prototype属性

复制代码
class A {
}

class B extends A {
}

B.__proto__ === A    // true
B.prototype.__proto__ === A.prototype  // true

实例中:

子类实例的__proto__的__proto__指向父类的__proto__。也就说子类实例的原型的原型指向父类实例的原型

复制代码
class A {
}

class B extends A {
}

const a = new A();
const b = new B();

b.__proto__.__proto__ === a.__proto__  // true
相关推荐
Amewin1 小时前
在vue3+uniapp+vite中挂载全局属性方法
javascript·vue.js·uni-app
玖釉-1 小时前
用 Vue + DeepSeek 打造一个智能聊天网站(完整前后端项目开源)
前端·javascript·vue.js
zhangyao9403302 小时前
关于js导入Excel时,Excel的(年/月/日)日期是五位数字的问题。以及对Excel日期存在的错误的分析和处理。
开发语言·javascript·excel
骑驴看星星a2 小时前
【Three.js--manual script】4.光照
android·开发语言·javascript
devincob8 小时前
js原生、vue导出、react导出、axios ( post请求方式)跨平台导出下载四种方式的demo
javascript·vue.js·react.js
编程社区管理员8 小时前
React 发送短信验证码和验证码校验功能组件
前端·javascript·react.js
葡萄城技术团队8 小时前
迎接下一代 React 框架:Next.js 16 核心能力解读
javascript·spring·react.js
全马必破三8 小时前
React“组件即函数”
前端·javascript·react.js
課代表8 小时前
JavaScript 中获取二维数组最大值
javascript·max·数组·递归·array·最大值·二维
02苏_9 小时前
ES6模板字符串
前端·ecmascript·es6