吃透原型与原型链

本文深入探讨了JavaScript中的原型和原型链概念。每个函数都有prototype属性,实例对象通过__proto__指向构造函数的原型。原型链用于属性查找,从实例到原型逐层搜索,直到Object.prototype。理解原型链的关键点包括:实例与构造函数的关系,属性查找机制以及共享属性的特性。掌握这些要点能帮助开发者更好地理解和使用JavaScript的继承机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


原型与原型链

理解原型:只要创建一个函数,就会按照特定的规则为这个函数创建一个prototype属性(原型对象)。默认情况下,所有原型对象都会获得一个名为constructor的属性,内部指针会指回关联的构造函数。每次调用构造函数创建new一个实例对象的时候,实例内部会有一个__proto__(隐式属性),内部指针会指回所对应的实例对象。
原型链:原型链是由__proto__串联起来的链状结构

原型链查找:当查找对象的某个属性时,会先从该对象的私有属性中查找,如果有则返回对应的值,如果没有则沿着对象的_proto_到原型中查找,如果原型中也没有,则沿着原型链继续向上查找。
当找到Object原型时,如果也依然没有要查找的属性, 则返回undefined,且停止查找,之所以会查找到Object的原型,是因为所有的构造方法在底层都会自动和Object建立继承关系,让自己的原型直接指向Object的原型。

在这里插入图片描述

参考文章:
原型与原型链

总结

五点总结:

  1. 所有函数的隐式属性都是Function的实例对象(Function.prototype);
  2. 所有对象的隐式属性都是Object的实例对象(Object.pretotype);
  3. 实例对象的隐式属性指向其构造函数的原型对象。
  4. 原型对象中包含着所有实例所共享的属性和方法。
  5. 不同实例之间的属性不共享。

上面的图看懂,并且牢记这五点,就能搞定原型链。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值