站长家园(原代码之家)(www.adminjie.com)网站源码,微信源码,游戏源码,商业源码分享平台。
当前位置:网站首页 技术文章 网络编程 正文

es6中super的用法是什么

时间:2022-05-06 [网络编程]作者:fabuyuan 浏览:6 次

super的用法:1、super作为函数时,用于表示父类的构造函数,语法为“constructor(){super();}”;2、super作为对象时,在普通方法中用于指向父类的原型对象,在静态方法中用于指向父类。

本教程操作环境:windows10系统、ECMAScript 6.0版、Dell G3电脑。

es6中super的用法是什么

第一种情况:super作为函数时,代表父类的构造函数

ES6要求,子类的构造函数,必须执行一次super函数

class A {}
class B extends A {
  constructor() {
    super();//子类的构造函数,必须执行一次super函数,代表父类的构造函数
  }
}

注意:虽然super代表父类的构造函数,但此时返回的时B的实例,即super内部的this指的是B的实例,因此super()相当于 A.prototype.constructor.call(this)

class A {
  constructor() {
    console.log(new.target.name);
  }
}
class B extends A {
  constructor() {
    super();
  }
}
new A() // A
new B() // B

上述代码中,new.target指向当前正在执行的函数,super()执行的时候,它指向的是子类B的构造函数,而不是父类A的构造函数,也就是说,super()内部的this指向B

super作为函数使用时,必须出现在子类的构造函数constructor中,否则会报错

class A {}
class B extends A {
  m() {
    super(); // 报错
  }
}

第二种情况:super作为对象时,在普通方法中,指向父类的原型对象,在静态方法中,指向父类

class A {
  p() {
    return 2;
  }
}
class B extends A {
  constructor() {
    super();//父类的构造函数
    console.log(super.p()); // 2
  }
}
let b = new B();

上面代码中,super作为函数时,代表父类的构造方法,作为对象时,指向父类的原型对象,即A.prototype,所以super.p()相当于A.prototype.p()

这里还需要注意,由于 super指向父类的原型,所以在父类实例上的属性或者方法,并不能通过super调用

class A {
  constructor() {
    this.p = 2;
  }
}
class B extends A {
  get m() {
    return super.p;
  }
}
let b = new B();
b.m // undefined

上面代码中,p是父类A实例的属性,super.p 就引用不到它

如果属性是定义在父类的原型上,则使用super就可以访问

class A {}
A.prototype.x = 2;
class B extends A {
  constructor() {
    super();
    console.log(super.x) // 2
  }
}
let b = new B();

上面代码中,属性x是定义在父类的原型对象上,所以可以使用super.x来访问

【相关推荐:javascript视频教程、web前端】

以上就是es6中super的用法是什么的详细内容,更多请关注站长家园其它相关文章!

本文标签:  ES6

转载请注明来源:es6中super的用法是什么

本文永久链接地址:https://www.adminjie.com/post/11978.html

免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。

  • 站长家园(原代码之家)会员升级
  • 最新文章
    • Oracle的12505错误怎么解决

      Oracle的12505错误怎么解决

      12505错误的出现原因是“service_name”和sid不一致。解决方法:1、使用“selectINSTANCE_NAMEfromv$instanc...

    • jquery移动端库有哪些

      jquery移动端库有哪些

      jquery移动端库有:1、Mobiscroll,用于触屏设备的旋转滚动、日期和时间选择;2、“Ion.Sound”,用于即时声音通知;3、mmenu,用于创建...

    • oracle怎么修改sequence

      oracle怎么修改sequence

      方法:1、用DROPSEQUENCE语句删除sequence,然后用Createsequence语句重新创建一个;2、用IncrementBy修改序列初始...

    • 什么是oracle表分区

      什么是oracle表分区

      在oracle中,表分区指的是当表中的数据不断增大时,将表中的数据在物理上存放到多个表空间,也即将表进行分区;表分区能够将表、索引或索引组织表进一步细分为段,这...

    • oracle怎么解决1067错误

      oracle怎么解决1067错误

      解决方法:1、进入“$NETWORKADMIN”将“listener.ora”文件中的IP地址信息修改为正确的;2、利用NetManager,在本地的监听程序...

    热门文章