原型对象、原型、原型链

一、原型对象

js规定,每一个构造函数都有一个prototype属性,指向另一个对象,我们称之为原型对象。

原型对象与实例对象:

原型对象可以挂载函数,对象实例化不会多次创建原型对象里面的函数,节约内存;

实例对象可以直接访问原型对象中的函数,先找实例对象属性或函数,找不到会再找原型对象中的的属性和函数。

构造函数和原型对象中的this都指向实例化的对象。

箭头函数不能做构造函数,因为箭头函数里没有this。

constructor属性------每个原型对象里面多有个constructor属性(constructor构造函数),该属性指向该原型对象的构造函数。

二、原型

对象都会有一个属性__proto__指向构造函数的prototype原型对象。

\[prototype] <==> proto

尽量不要修改这个属性,否则会对性能产生非常严重的影响。

三、原型链

__proto__属性的链状结构被称为原型链。

原型链的作用是为对象成员查找机制提供一个方向,或者说一条路线。

原型链查找规则:

1、当访问一个对象成员(属性/方法)时,首先查找这个对象自身有没有该成员(属性/方法)

2、如果没有就查找他的原型对象,也就是__proto__指向的prototype原型对象

3、如果还没有,就查找原型对象的原型对象,就是Object的原型对象

4、依次类推,知道找到Object为止(null)

instanceof可以用来检测构造函数.prototype是否存在于实例对象的原型链上。

四、原型继承

有些公共的属性和方法可以写到父级身上,自己通过继承也可以使用这些属性和方法。

js大多是借助原型对象实现继承的特性。

相关推荐
jump_jump24 分钟前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
swipe2 小时前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
kyriewen2 小时前
前端错误监控最全指南:捕获 JS 异常、Promise 拒绝、资源加载失败,附上报代码
前端·javascript·监控
大家的林语冰3 小时前
ESLint 近期动态大全,新版本正式发布,antfu 大佬推荐的插件也更新了!
前端·javascript·前端工程化
胡志辉4 小时前
深入浅出 call、apply、bind
前端·javascript·后端
十九画生7 小时前
parentID ``` JavaScript 是区分大小写的,所以这两个不是同一个字段。 第二,`parent` 没有声明。 应该先写: `
javascript
怕浪猫7 小时前
Electron 开发实战(十六):总结与展望|生态现状、框架对比、行业趋势与学习指南
前端·javascript·electron
ZengLiangYi8 小时前
批量导入 1000 条对话的性能优化实战
javascript·后端·架构
竹林8188 小时前
用 wagmi v2 + viem 监听合约事件时踩的坑,我花了两天才把"遗漏事件"修好
javascript
小花酱酱9 小时前
QQ群里只有你一个人?邪门歪道破局之路——AstrBot
javascript