前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >搞明白prototype和__proto__

搞明白prototype和__proto__

作者头像
xinxin-l
发布2022-03-29 08:10:38
3340
发布2022-03-29 08:10:38
举报

实践是最好的证明,一定要相信这句话

在我自己动手敲代码之前,对于原型对象、父类子类等的了解只是停留在概念上,对于prototype和proto也是自认为明白清楚,但在真正动手敲一遍代码实现之后,才发现原来真的是需要自己边敲边领悟的啊

代码就放在下面了,很简单,但是需要不停地去琢磨答案为什么是这样,最终会明白,哦,原来是这样~

代码语言:javascript
复制


class A {
}
class B extends A {
}
console.log(A)//class A
console.log(A.prototype)//{}
console.log(A.__proto__)//{}
console.log(A.__proto__===Function.prototype)//true
console.log(A.__proto__.prototype)//undefined
console.log(A.prototype.__proto__)//[Object:null prototype]{}
console.log(A.prototype.prototype)//undefined

console.log(B)//class B extends A
console.log(B.__proto__)//class A  B的父类是A
console.log(B.prototype)//A {}  说明B的原型对象是A的原型对象的实例
console.log(B.prototype.prototype)//undefined
console.log(B.prototype.__proto__===A.prototype)//true
console.log(B.__proto__.prototype===A.prototype)//true


//实例
let a=new A()
let b=new B()
console.log(b.__proto__)//A{}  等于B的原型对象的值
console.log(b.__proto__.prototype)//undefined
console.log(a.__proto__)//{}
console.log(b.__proto__.__proto__)//{}  指向的是父类实例的__proto__
//即子类的原型的原型,是父类的原型

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-02-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 实践是最好的证明,一定要相信这句话
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档