super的两个作用
super与实例没有什么关系,它本身有两个作用的,参考如下理解:
1.super可以当函数用。super作为函数调用时,表示父类的构造函数。示例:
class Par {
constructor() {
this.num = 21;
}
}
class Chil extends Par {
constructor() {
//继承父类的构造函数constructor
super()
}
}
var p = new Chil();
// 子类的实例上,可以调用num属性,则说明子类的构造函数中
// 通过 super() 继承了父类的构造函数。
console.log(p.num) //21
super() 表示的父类的构造器,那么super() 中的参数,自然表示父类构造器中的参数。
class Par {
// 为了区分父类与子类的参数,这里起名为username1
constructor(username1) { //username1接收username的值
this.username = username1; //所以this.username="小慕"
}
}
class Chil extends Par {
constructor(username) { //username接收的就是下面实例化的参数"小慕"
super(username)//super表示父类的构造器,所以这里是把username传递给父类构造器
}
}
var p = new Chil("小慕"); //实例化的时候,传入参数"小慕"
// 实例化对象,会继承类的属性和方法,Chil类继承了父类的属性username,所以Chil类的实例化对象
//也就可以调用到username,输出"小慕"
console.log(p.username) //小慕
2.可以作为对象使用。super 作为对象使用时, 在普通的方法中,指向的是父类的原型对象。在静态方法中,指向的是父类。
也就是作为对象去使用分了两种情况,扩展一下,作为了解:
class A {
constructor() {
}
// 普通方法,放在A原型上的。
say() {
console.log("普通方法")
}
// 加static定义的叫做静态方法,能被子类继承,但是不能被实例化对象继承。
static greeting() {
console.log("静态方法")
}
}
class B extends A {
constructor() {
super(); //在构造器中,作为函数调用,是继承父类构造器
}
bsay() {
// 在普通方法中,super指向的是父类原型对象,即prototype,
// 所以能访问父类原型上的方法。
super.say() // "普通方法";
}
static bgreeting() {
// 在静态方法中,super指向的是父类,能访问父类的静态属性和静态方法。
super.greeting(); //"静态方法"
}
}
let xiao = new B();
xiao.bsay();
B.bgreeting();
super的两个作用的更多相关文章
- 对TControl和TWinControl相同与不同之处的深刻理解(每一个WinControl就相当于扮演了整个Windows的窗口管理角色,主要是窗口显示和窗口大小)——TWinControl就两个作用(管理子控件的功能和调用句柄API的功能)
TControl是图形控件,它本身没有句柄,所以不能直接使用WINAPI显示,调整位置,发消息等等,只能想办法间接取得想要的效果,但是可以直接使用一些不需要句柄的API,比如InvalidateRec ...
- java中super的两种用法
通过用static来定义方法或成员,为我们编程提供了某种便利,从某种程度上可以说它类似于C语言中的全局函数和全局变量.但是,并不是说有了这种便利,你便可以随处使用,如果那样的话,你便需要认真考虑一下自 ...
- return在Java中的两个作用
Java中return的两个作用: (1)返回方法指定类型的值(这个值总是确定的),也可以是对象 (2)方法的结束
- C#中return的两个作用
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
- super(classname,self).__init__() 作用
- Volatile关键字的两个作用
1.保证修饰的变量对所有线程的可见性,这里的“可见性”是指当一条线程修改了这个值,新值对于其他线程来说是可以立即得知的. 2.禁止指令重新排序化
- 构造方法,this,super,final,static
1构造方法 一个Person类,属性都被private了,外界无法直接访问属性,必须对外提供相应的set和get方法.但如果需要在创建对象的同时明确对象的属性值,就需要构造方法了. 1.1定义 构建创 ...
- this&super两个关键字的意义和用法
"this",作为一个特殊的关键字,它的规则如下: 1.可以表示构造函数传递.this(a,b)表示调用另外一个构造函数.这里面的this就是一个特殊语法,不是变量,没有什么类型. ...
- 7 html-webpack-plugin的两个基本作用
html-webpack-plugin的作用: 1.在内存中根据我们的index模板页面,生成一个内存里面的首页 2.当使用html-webpack-plugin之后,我们不再需要手动处理bundle ...
随机推荐
- 微信小程序云开发-云存储-上传单个视频到云存储并显示到页面上
一.wxml文件 <!-- 上传视频到云存储 --> <button bindtap="chooseVideo" type="primary" ...
- 你有没有乱用“leader”,担当是个好东西
PS:此文为个人认知,不足处请多多批评. 近期在一线leader(经理)身上发现了几个case,然后又回想起前几年自己做的一些傻事,可能都属于明面上leader不会说什么,但私下会有情绪的类型: Ca ...
- C++第三十六篇 -- 为第一个驱动程序进行调试
工具是VMware12+Win10+VS2017+WDK1809 https://blog.csdn.net/qq_21763381/article/details/83242916 首先分清楚主计算 ...
- CAS 原理 应用
原子CAS操作 原子操作指令里,有原子加,原子减,cas到底是什么呢? 首先看一段代码, bool compare_and_swap(int *accum, int *dest, int newval ...
- jquery版本更新后无live函数的处理.TypeError: $(...).live is not a function
jquery live函数语法 jquery版本更新, 发现一个问题: jq自带的live没有了.控制台下会有如下的提示:火狐: TypeError: $(...).live is not a fun ...
- 【Azure 应用服务】Azure Function HTTP 触发后, 230秒就超时。而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间?
问题描述 Azure Function HTTP 触发后, 230秒就超时,而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间? 问题分析 查阅官方文档,对函数应用超时持续时间有 ...
- 《手把手教你》系列技巧篇(十四)-java+ selenium自动化测试-元素定位大法之By xpath上卷(详细教程)
1.简介 按宏哥计划,本文继续介绍WebDriver关于元素定位大法,这篇介绍定位倒数二个方法:By xpath.xpath 的定位方法, 非常强大. 使用这种方法几乎可以定位到页面上的任意元素. ...
- LeetCode入门指南 之 链表
83. 删除排序链表中的重复元素 存在一个按升序排列的链表,给你这个链表的头节点 head ,请你删除所有重复的元素,使每个元素 只出现一次 .返回同样按升序排列的结果链表. class Soluti ...
- Android 自定义属性(attrs)、样式(Style)、主题(Theme)
Android 自定义属性(attrs).样式(Style).主题(Theme) https://www.cnblogs.com/dandre/p/4507024.html https://blog. ...
- 超详细!Vue-Router手把手教程
目录 1,router-view 2,router-link 3,重定向redirect 4,路由别名 5,路由传参props 5.1,布尔模式 5.2,对象模式 5.3,函数模式 6,路由守卫 6. ...