构造函数,原型,实例,类的关系整理

视频来源js原型链、构造函数和类_哔哩哔哩_bilibili

如视频所说,构造函数的prototype指向原型,实例化的对象的__proto__指向原型,原型通过constructor指向构造函数,正如class里面的constructor方法就相当于Person构造函数一样,而我们在class中写在constructor之外的方法则是被默认放到了原型上面即相当于原本的Person.prototype.fn,这样实例化的对象都能访问到。

实例化对象的__proto__指向的是构造函数的原型,构造函数的原型的__proto__指向的是Object.prototype,Object.prototype的__proto__指向的是null。在调试时,[[prototype]]就相当于

proto,然后在写class的时候,要注意,class都是小写的,空一格接类名,然后直接接的{},有点像style里面类名的写法。其中的constructor里面仍然是用this来声明实例的属性或者方法的,如

class Person{

constructor(name,age){

this.name = name

this.age = age

}

}

这里使用extends的时候,要记得重新写一遍constructor(){},然后里面的super()这样的写法,要记忆一下,关键的在于,类的继承是为了让子的实例化对象能够使用祖先的原型上的数据,所以类.prototype的__proto__要指向祖先.prototype。

相关推荐
进击的大海贼2 分钟前
QT-C++ 自定义加工统计通用模块
开发语言·c++·qt
Rhys..3 分钟前
JS - npm init
开发语言·javascript·npm
newxtc9 分钟前
【 广州产权交易所-注册安全分析报告-无验证方式导致安全隐患】
开发语言·人工智能·selenium·安全·yolo
兩尛13 分钟前
java八股-操作系统
java·开发语言
wjs202430 分钟前
SQL 日期处理指南
开发语言
川石课堂软件测试42 分钟前
CSS中常用的几种定位。
开发语言·css·python·网络协议·http·html·pytest
友友马1 小时前
『 QT 』QT信号机制深度解析
开发语言·qt
清风wxy1 小时前
C语言基础数组作业(冒泡算法)
c语言·开发语言·数据结构·c++·windows·算法
程序0071 小时前
HTML+JS+CSS实现汽车官网
javascript·css·html
凤山老林1 小时前
SpringBoot 启动时执行某些操作的 8 种方式
java·开发语言·spring boot·后端