Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >派生类究竟从基类继承了什么?

派生类究竟从基类继承了什么?
EN

Stack Overflow用户
提问于 2020-01-17 11:57:36
回答 2查看 304关注 0票数 5

我目前正在为Javascript学习ES6类,我似乎理解它们的概念,但是我不理解派生类从它的基类继承了什么。是班里的方法吗?假设一个类的方法是该类的属性是安全的吗?在这种情况下,它们是原型的一部分,因此由原型链中的对象继承。构造函数呢?属性是在构造函数中定义的吗?

谢谢你的考虑!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-01-17 12:42:45

类或多或少只是建立原型继承的语法糖。

代码语言:javascript
运行
AI代码解释
复制
class Derived extends Base {}

等于

代码语言:javascript
运行
AI代码解释
复制
function Derived(...args) {
  return Base.apply(this, args);
}

Object.setPrototypeOf(Derived, Base);
Object.setPrototypeOf(Derived.prototype, Base.prototype);

super和将来的公共和私有类字段都有一些“魔力”,但对象之间的基本关系是相同的。

是否可以安全地假定类的方法是该类的属性?在这种情况下,它们是原型的一部分,因此由原型链中的对象继承。

是的,方法成为相应的prototype对象的属性,所有实例都从该对象继承。也就是说。

代码语言:javascript
运行
AI代码解释
复制
class Foo {
  bar() {}
}

等于

代码语言:javascript
运行
AI代码解释
复制
function Foo() {}
Foo.prototype.bar = function() {}

而且,由于“基类”property对象位于派生类的原型链中,因此它的所有方法都可用于派生类的实例。

是在构造函数中定义的属性吗?

“继承”是个错误的词。属性是在实例本身上创建的,因为构造函数就是这样工作的。

假设这个过程是这样的:

代码语言:javascript
运行
AI代码解释
复制
// Create new instance
var newInstance = Object.create(Derived.prototype);

// Call base constructor with `this` set to new instance
Base.apply(newInstance);

// Call derived constructor with `this` set to new instance
Derived.apply(newInstance);

如果基本构造函数包含类似this.base = 42;的内容,那么该属性将直接在新实例上创建,因为this引用了新实例。

注意:实际上,由于扩展内置类(如Array )需要特殊处理,实际上确切的流有一点不同,但最终结果大致相同。

您没有询问static方法,但这些方法仍然是继承的一部分。static方法成为构造函数本身的属性。

代码语言:javascript
运行
AI代码解释
复制
class Foo {
  static bar() {}
}

等于

代码语言:javascript
运行
AI代码解释
复制
function Foo() {}
Foo.bar = function() {}

因为基类的构造函数成为派生类构造函数的原型,因此基构造函数上定义的所有属性都可用于派生构造函数。

浏览器中的开发工具实际上可以向您展示所有这些:

代码语言:javascript
运行
AI代码解释
复制
class Base {

  static staticBase() {}
  
  constructor() {
    this.base = 42;
  }
  
  fromBase() {}
}

class Derived extends Base {

  static staticDervied() {}
    
  constructor() {
    super(); // necessary since we extend base
    this.derived = 21;
  }
  
  fromDerived() {}
}

console.dir(Derived);
console.dir(new Derived());

票数 7
EN

Stack Overflow用户

发布于 2020-02-03 05:30:04

关于基本的es06示例- https://exploringjs.com/es6/ch_classes.html#details-of-subclassing,有很多很好的资源。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59794094

复制
相关文章
Droid@screen:在PC屏幕上显示Android手机屏幕
这里介绍一款工具——Droid@screen,用来获取手机屏幕,显示在PC屏幕上。它集截图、录像等多种功能于一体。
流柯
2018/08/30
2.3K0
Android 手机如何拍摄RAW图
专业玩摄影的朋友可能更倾向于使用相机的RAW格式,然后自己做后期处理,而不是直接拍摄JPEG格式的图片。
雪月清
2020/09/01
3.6K0
Android 手机如何拍摄RAW图
Android极速开发之手机屏幕
获取屏幕宽高 手机横竖屏的判断 public class ScreenUtils { public static int getWidth(Context context) { WindowManager manager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE); DisplayMetrics outMetrics = new DisplayMetrics();
Javen
2018/08/21
6040
Android动态控制手机屏幕方向
想要在应用中控制手机屏幕显示方向,可以在onCreate中用一句代码搞定: setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR); 手机屏幕的朝向有7个可选值,分别如下 SCREEN_ORIENTATION_BEHIND //继承Activity堆栈中当前Activity下面的那个Activity的方向 SCREEN_ORIENTATION_LANDSCAPE // 横屏(风景照) ,显示时宽度大于高度 SCREEN_O
张拭心 shixinzhang
2022/11/30
1.3K0
Android手机 全面屏(18:9屏幕)适配指南
从小米MIX 1发布以来,越来越多所谓“全面屏”手机发布,如三星S8,小米MIX2,VIVO X20,Google Pixel2等等...2017年下半年开始,“全面屏”将大范围覆盖,低至千元机水平,就像当年手机屏幕从720P到1080P过渡一样,历史车轮,滚滚向前,不可阻挡!
用户2802329
2018/08/07
1.9K0
Android手机 全面屏(18:9屏幕)适配指南
Android手机 全面屏(18:9屏幕)适配指南
从小米MIX 1发布以来,越来越多所谓“全面屏”手机发布,如三星S8,小米MIX2,VIVO X20,Google Pixel2等等…2017年下半年开始,“全面屏”将大范围覆盖,低至千元机水平,就像当年手机屏幕从720P到1080P过渡一样,历史车轮,滚滚向前,不可阻挡!
程思扬
2022/01/10
1.6K0
Android手机 全面屏(18:9屏幕)适配指南
手机拍摄动态照片如何制作成GIF表情或视频?以小米手机&iPhone为例转换
目前市面上的手机基本都支持动态照片的功能,iPhone上叫实况照片,Android以小米为例叫动态照片,其原理大概是拍摄一组照片合并展示,长按照片就可以播放动态过程,并且是有声音的。那么问题来了,拍摄下的动态照片如何制作成GIF表情或视频呢?本文主要解决这个需求。这里不使用任何第三方软件即可实现转换。
用户7715973
2021/02/02
32.9K0
浅谈屏幕拍摄泄密跟踪的检测技术
前言关注屏幕拍照安全检测技术介绍数字盲水印屏幕矢量水印摄像头检测屏摄检测缓解办法参考资料
安全乐观主义
2020/05/08
11K0
Anbox:在 Linux 上运行 Android 应用程序的简单方式
Anbox 是 “Android in a box” 的缩写。Anbox 是一个基于容器的方法,可以在普通的 GNU/Linux 系统上启动完整的 Android 系统。
用户8639654
2021/09/23
5.4K0
【Android 屏幕适配】屏幕适配基础概念 ④ ( 屏幕适配限定符 | 手机/平板电脑设备屏幕适配 )
Android 系统加载应用资源时 , 会根据当前运行应用的设备的相关属性 , 如 : 屏幕尺寸 / 屏幕像素密度 / 宽高比 / 屏幕方向 等属性 , 加载不同的屏幕适配限定符目录下的资源 ;
韩曙亮
2023/03/30
7.2K0
【Android 屏幕适配】屏幕适配基础概念 ④ ( 屏幕适配限定符 | 手机/平板电脑设备屏幕适配 )
现在,以编程方式在 Electron 中上传文件,是非常简单的!
本文主要探讨了在 Electron 应用中如何实现上传文件到服务器的功能,同时通过本地代理服务器来获取完整的cookie。首先介绍了在 Electron 应用中如何通过 XHR 上传文件到服务器,然后介绍了如何通过 LocalStorage 将文件保存在本地。最后,本文介绍了一种使用 Electron 创建本地代理服务器,从而获取完整的cookie的方法。
ios122
2017/12/27
5.3K0
现在,以编程方式在 Electron 中上传文件,是非常简单的!
在Windows上以服务方式运行 MSOPenTech/Redis
ServiceStack.Redis 使用教程里提到Redis最好还是部署到Linux下去,Windows只是用来做开发环境,现在这个命题发生改变了,在Windows上也可以部署生产环境的Redis,这都要感谢微软的开放,把Redis在Windows上的环境给我们搞定了,最新的版本已经支持64位了。那么Redis在32位上的存储能力受限于可用的地址空间,也就是3GB。 要在Windows上运行64位Redis ,可以从https://github.com/MSOpenTech/redis 获取一份Redis
张善友
2018/01/29
1.4K0
在Windows上以服务方式运行 MSOPenTech/Redis
【Android从零单排系列一】《Android系统发展史》
9.Android 4.0:​Ice Cream Sandwich(冰激凌三明治)
再见孙悟空_
2023/02/10
1.4K0
【Android从零单排系列一】《Android系统发展史》
点击加载更多

相似问题

Android以编程方式拍摄屏幕快照

51

在android中以编程方式拍摄屏幕截图

40

以编程方式拍摄屏幕快照

11

以编程方式拍摄位图屏幕截图

12

更改方向后以编程方式拍摄屏幕

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档