- 每个对象都会在其内部初始化一个属性,就是
__proto__,当我们访问一个对象的属性时 - 如果这个对象内部不存在这个属性,那么他就会去
__proto__里找这个属性,这个__proto__又会有自己的__proto__,于是就这样一直找下去,也就是我们平时所说的原型链的概念。按照标准,__proto__是不对外公开的,也就是说是个私有属性 - 关系:
instance.constructor.prototype == instance.__proto__
// eg.
var a = {}
a.constructor.prototype == a.__proto__
-
特点:
JavaScript对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于自己的原型副本。当我们修改原型时,与之相关的对象也会继承这一改变
-
当我们需要一个属性的时,
Javascript引擎会先看当前对象中是否有这个属性, 如果没有的 -
就会查找他的
Prototype对象是否有这个属性,如此递推下去,一直检索到Object内建对象 -
原型:
JavaScript的所有对象中都包含了一个[__proto__]内部属性,这个属性所对应的就是该对象的原型- JavaScript的函数对象,除了原型
[__proto__]之外,还预置了prototype属性 - 当函数对象作为构造函数创建实例时,该 prototype 属性值将被作为实例对象的原型
[__proto__]。
-
原型链:
- 当一个对象调用的属性/方法自身不存在时,就会去自己
[__proto__]关联的前辈prototype对象上去找 - 如果没找到,就会去该
prototype原型[__proto__]关联的前辈prototype去找。依次类推,直到找到属性/方法或undefined为止。从而形成了所谓的“原型链”
- 当一个对象调用的属性/方法自身不存在时,就会去自己
-
原型特点:
JavaScript对象是通过引用来传递的,当修改原型时,与之相关的对象也会继承这一改变
本文详细讲解了JavaScript中对象的__proto__属性及其原型链原理,探讨了对象引用和原型共享的特点,以及如何通过constructor.prototype与__proto__进行关联。重点介绍了原型链查找过程和修改原型的影响。
911

被折叠的 条评论
为什么被折叠?



