原型对象、原型、原型链

一、原型对象

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

原型对象与实例对象:

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

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

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

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

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

二、原型

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

\[prototype\]\] \<==\> __proto__ 尽量不要修改这个属性,否则会对性能产生非常严重的影响。 ### 三、原型链 __proto__属性的链状结构被称为原型链。 原型链的作用是为对象成员查找机制提供一个方向,或者说一条路线。 **原型链查找规则:** 1、当访问一个对象成员(属性/方法)时,首先查找这个对象自身有没有该成员(属性/方法) 2、如果没有就查找他的原型对象,也就是__proto__指向的prototype原型对象 3、如果还没有,就查找原型对象的原型对象,就是Object的原型对象 4、依次类推,知道找到Object为止(null) instanceof可以用来检测构造函数.prototype是否存在于实例对象的原型链上。 ### 四、原型继承 有些公共的属性和方法可以写到父级身上,自己通过继承也可以使用这些属性和方法。 **js大多是借助原型对象实现继承的特性。**

相关推荐
能来帮帮蒟蒻吗1 小时前
Go语言学习(15)结构体标签与反射机制
开发语言·笔记·学习·golang
陈皮话梅糖@3 小时前
使用 Provider 和 GetX 实现 Flutter 局部刷新的几个示例
开发语言·javascript·flutter
hvinsion4 小时前
基于PyQt5的自动化任务管理软件:高效、智能的任务调度与执行管理
开发语言·python·自动化·自动化任务管理
Aphelios3804 小时前
Java全栈面试宝典:线程机制与Spring IOC容器深度解析
java·开发语言·jvm·学习·rbac
qq_529835354 小时前
装饰器模式:如何用Java打扮一个对象?
java·开发语言·装饰器模式
日暮南城故里4 小时前
Java学习------源码解析之StringBuilder
java·开发语言·学习·源码
Vitalia5 小时前
从零开始学Rust:枚举(enum)与模式匹配核心机制
开发语言·后端·rust
双叶8365 小时前
(C语言)虚数运算(结构体教程)(指针解法)(C语言教程)
c语言·开发语言·数据结构·c++·算法·microsoft
Yolo@~7 小时前
个人网站:基于html、css、js网页开发界面
javascript·css·html
斯~内克7 小时前
Electron 菜单系统深度解析:从基础到高级实践
前端·javascript·electron