原型和原型链

原型和原型链

构造函数

js 复制代码
function Fn(){
}

const fn1 = new Fn();
fn1.test = 'hello word!'

其中,fn 就是一个构造函数,fn 就是一个我们使用构造函数fn创建的实例对象; ok,理解了构造函数实例对象以及他们之间的关系。

prototype

js 复制代码
function Fn(){
}

//prototype只有构造函数才会有的属性~
Fn.prototype.test = 'hello word!'

const fn1 = new Fn();
const fn2 = new Fn();
console.info(fn1.test)//hello word
console.info(fn2.test)//hello word

代码中的prototype 添加的属性,就是添加到调用构造函数创建出来的实例对象的原型对象中。也就是🌰中fn1fn2的原型对象。

原型 又是什么呢? 当我们创建一个对象的时候(null除外),他都会关联另外的一个对象这里关联的意思就是所谓的"继承",而所关联的对象就是创建对象的原型。

那我们应该如何表达实例实例的原型的关系呢?

好,继续学习解决这个问题!

proto

每一个js对象都有一个 __proto__属性,用来指向该对象的原型。并且fn1.__proto__ === Fn.prototype

因此,实例和实例原型的关系就是fn1和fn1.__proto__的关系

constructor

当我们想找一个原型的构造函数时要怎么做呢?

js 复制代码
function Fn(){
}
console.info(Fn.prototype.constructor === Fn)//true

经过上面学习我们又知道了

js 复制代码
function Fn(){
}
const fn1 = new Fn();
console.info(Fn.prototype.constructor === Fn)//true
console.info(fn1.__proto__ === Fn.prototype)//true
console.info(Object.getPrototype(fn1) === Fn.prototype)//true

实例与原型

当我们在实例中查找属性查找不到的时候就会自动向原型去找,比如我们在调用对象的方法的时候,这些方法并没有在实例对象中。因此,会向上面的原型中查找。

js 复制代码
function Fn(){
}

//prototype只有构造函数才会有的属性~
Fn.prototype.test = 'hello word!'

const fn1 = new Fn();
const fn2 = new Fn();
console.info(fn1.test)//hello word
console.info(fn2.test)//hello word

这是上面的🌰,我们直接拿过来了。test在我们的实例对象fn1fn2中并没有。那这个属性是从哪里来的呢?就是去上层的原型对象中获取的。

原型的原型

那如果在实例对象的原型中还是没有找到这个属性呢?

当然,会去更上层的原型对象去找,这里的原型的原型对象指Object.prototype。因此,又有了

js 复制代码
Fn.prototype.__proto__===Object.prototype//true

原型链

到现在我们可以引出另一个新的概念了,原型链

原型链是什么意思呢?

就像上面那个例子,当我们去查找一个属性test的时候,实例对象fn1没有就会去原型对象fn1.__proto__(Fn.prototype)上去找,原型对象上没有就会去原型对象的原型对象Object.prototype去找。那如果还找不到呢?那就会继续向原型对象的原型对象的原型对象上去找...

那如果找不到这个属性就不会停下来吗? 当然会啦!当找到null 为止就不会继续向上寻找了。null表示没有对象,此处不应该有值

到此,原型链的意思就是这个查找过程形成的链式路径

扩展

  • 继承 继承意味着复制的操作,然而JavaScript默认并不会复制对象的属性,相反,JavaScript只是在两个对象之间创建一个关联。这样,一个对象就可以通过委托访问另一个对象的属性和函数,所以与其叫继承,委托的说法更为准确些。 ---《你不知道的JavaScript》
  • proto 尽管大多浏览器都支持这种访问原型的方法,但是它并不是一个标准的访问原型的方法。可以通过Object.getPrototype()来访问原型。

学习笔记

不是什么学习文档,就是整理的学习笔记。用来自己学习、梳理思路、查漏补缺。


2023年12月04

相关推荐
小李小李不讲道理7 分钟前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻8 分钟前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front1 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰1 小时前
纯flex布局来写瀑布流
前端·javascript·css
一袋米扛几楼982 小时前
【软件安全】什么是XSS(Cross-Site Scripting,跨站脚本)?
前端·安全·xss
向上的车轮2 小时前
Actix Web适合什么类型的Web应用?可以部署 Java 或 .NET 的应用程序?
java·前端·rust·.net
XiaoYu20023 小时前
第1章 核心竞争力和职业规划
前端·面试·程序员
excel3 小时前
🧩 深入浅出讲解:analyzeScriptBindings —— Vue 如何分析 <script> 里的变量绑定
前端
蓝瑟3 小时前
AI时代程序员如何高效提问与开发工作?
前端·ai编程
林晓lx3 小时前
使用Git钩子+ husky + lint语法检查提高前端项目代码质量
前端·git·gitlab·源代码管理