ES派生类的prototype方法中,不能访问super的解决方案

1 下面的B.prototype.compile方法中,无法访问super

javascript 复制代码
class A {
  compile() {
    console.log('A')
  }
}

class B extends A {
  compile() {
    super.compile()
    console.log('B')
  }
}

B.prototype.compile = function() {
  super.compile() // 报错,不可以在此处使用super
  console.log('B2')
} 

const b = new B()
b.compile() // A B2

2 替代方法如下

javascript 复制代码
class A {
  compile() {
    console.log('A')
  }
}

class B extends A {
  compile() {
    super.compile()
    console.log('B')
  }
}

B.prototype.compile = function() {
  A.prototype.compile.call(this) // 替代super
  console.log('B2')
} 

const b = new B()
b.compile() 

// A 
// B2
相关推荐
search710 小时前
前端设计:CRG 3--CDC error
前端
治金的blog10 小时前
vben-admin和vite,ant-design-vue的结合的联系
前端·vscode
利刃大大11 小时前
【Vue】Vue2 和 Vue3 的区别
前端·javascript·vue.js
Lhuu(重开版12 小时前
JS:正则表达式和作用域
开发语言·javascript·正则表达式
荔枝一杯酸牛奶13 小时前
HTML 表单与表格布局实战:两个经典作业案例详解
前端·html
Charlie_lll13 小时前
学习Three.js–纹理贴图(Texture)
前端·three.js
yuguo.im13 小时前
我开源了一个 GrapesJS 插件
前端·javascript·开源·grapesjs
安且惜13 小时前
带弹窗的页面--以表格形式展示
前端·javascript·vue.js
摘星编程14 小时前
用React Native开发OpenHarmony应用:NFC读取标签数据
javascript·react native·react.js
GISer_Jing14 小时前
AI驱动营销:业务技术栈实战(From AIGC,待总结)
前端·人工智能·aigc·reactjs