prototype, __proto__ ,constructor 之间的关系。原型对象,原型链

在 JavaScript 中,每个对象都有一个 prototype 属性和一个 proto 属性,以及一个 constructor 属性。这三者之间的关系如下:

  1. prototype 属性:每个函数对象都有一个 prototype 属性,它指向一个对象。这个对象被称为原型对象,它包含了所有实例共享的属性和方法。

  2. proto 属性:每个对象都有一个 proto 属性,它指向该对象的原型对象。通过这个属性,可以访问到原型对象中的属性和方法。

  3. constructor 属性:每个原型对象都有一个 constructor 属性,它指向该原型对象所属的构造函数。

因此,可以总结出以下几点:
  1. 所有的函数对象都有一个 prototype 属性,指向该函数的原型对象,原型对象中包含所有实例共享的属性和方法。

  2. 所有的对象都有一个 proto 属性,指向该对象的原型对象,通过 proto 属性可以访问到原型对象中的属性和方法。

  3. 每个原型对象都有一个 constructor 属性,指向该原型对象所属的构造函数。

  4. 对象可以通过原型链继承原型对象中的属性和方法,当对象访问一个属性或方法时,如果该对象本身没有该属性或方法,会沿着原型链向上查找,直到找到该属性或方法或查找到原型链的顶部为止。

总的来说,原型对象和原型链是 JavaScript 中非常重要的概念,它们在实现继承、共享属性和方法等方面都有非常重要的作用。

在 JavaScript 中,每个函数对象都有一个 prototype 属性,它指向一个对象。这个对象被称为原型对象,它包含了所有实例共享的属性和方法。原型对象也是一个对象,因此它也有自己的原型对象,这就构成了一个原型链。

原型链是一种由原型对象构成的链式结构,用于实现 JavaScript 中的继承和属性查找。当我们访问一个对象的属性或方法时,如果该对象本身没有该属性或方法,JavaScript 引擎会沿着原型链向上查找,直到找到该属性或方法或查找到原型链的顶部为止。

例如,假设有一个函数对象 Person,它的原型对象中有一个属性 name,现在创建一个实例对象 p,那么当我们访问 p.name 属性时,JavaScript 引擎会首先查找 p 对象本身是否有 name 属性,如果没有,它会沿着原型链向上查找,找到 Person 的原型对象,查找该对象是否有 name 属性,如果找到了,就返回该属性值,否则继续向上查找,直到查找到原型链的顶部为止。

通过原型链,JavaScript 实现了基于原型的继承,它可以让子类对象共享父类对象中的属性和方法,从而避免了重复定义和维护代码的复杂性。同时,原型链也是 JavaScript 中属性查找的重要机制,它使得 JavaScript 具有动态绑定和多态性等特性。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容