首页  >  文章  >  web前端  >  JavaScript 继承中 proto 和 constructor.prototype 有什么区别?

JavaScript 继承中 proto 和 constructor.prototype 有什么区别?

Barbara Streisand
Barbara Streisand原创
2024-10-21 14:57:30414浏览

What's the Difference Between proto and constructor.prototype in JavaScript Inheritance?

理解 proto 和 constructor.prototype

理解 __proto__ 属性和 constructor.prototype 之间的区别很重要使用 JavaScript 对象时的 constructor.prototype。

proto 和原型链

每个 JavaScript 对象都有一个引用原型对象的内部 __proto__ 属性它的构造函数。该原型对象包含该类型对象的共享属性和方法。

演示

考虑以下代码:

<code class="js">function Gadget(name, color) {
  this.name = name;
  this.color = color;
}

Gadget.prototype.rating = 3;

var newtoy = new Gadget("webcam", "black");</code>

在此例如,newtoy 的 __proto__ 将指向 Gadget.prototype,其 rating 属性值为 3。因此,访问 newtoy.__proto__.__proto__.__proto__ 将返回 null,因为它没有进一步的原型对象。

constructor.prototype.constructor.prototype

这个复杂的表达式并不直接访问原型链。相反,它会尝试访问 Gadget 构造函数的 constructor.prototype 的 constructor.prototype 的 constructor.prototype 。在本例中,它是 Gadget 构造函数本身。因此,它一直指向 Gadget.prototype。

在 Internet Explorer 中检查 Null

Internet Explorer 不支持 __proto__ 属性。要在这种情况下检查 null,可以使用 hasOwnProperty() 方法来确定 __proto__ 是否存在。例如:

<code class="js">if (!(newtoy.hasOwnProperty("__proto__"))) {
  // `__proto__` is not supported
}</code>

视觉表示

为了帮助理解,这里有一个原型链的视觉图以及 __proto__ 和 constructor.prototype 之间的关系:

[原型链和 __proto__/constructor.prototype 关系的图像]

这张简化的图全面概述了 JavaScript 对象的内部工作原理,有助于阐明这些属性及其角色之间的区别在原型链中。

以上是JavaScript 继承中 proto 和 constructor.prototype 有什么区别?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn