繁体   English   中英

澄清:Javascript原型更新混乱

[英]Clarification: Javascript prototype update confusion

可能的答案 ,但答案显示观察到的内容,但不能解释为什么会这样发生。

让我们创建三个函数构造函数。

function A() {
}

function B() {
}

function C() {
}
C.prototype.nm = "C";
B.prototype = new A()
var obj = new B()
B.prototype = new C()
console.log(obj.nm); // prints, undefined.

因此,在最后一行之后,我期望'obj'从C原型接收属性,但事实并非如此。 这是否意味着一旦创建了对象,它便会绑定到在创建过程中分配的任何原型? 为什么这样,我的意思是我可以通过原型接收对象的实时更新,但是如果仅更改构造函数的原型属性就可以从多个对象获取更新,那不是更好吗?

您没有为B分配任何特定的原型属性,因此继承链断开了。

这是否意味着一旦创建了对象,它就会与创建过程中分配的任何原型绑定在一起?

对,就是这样。 对象从其[[Prototype]]内部属性中继承了对象的属性。

创建实例时设置该属性:

13.2.2 [[Construct]]

  • proto为使用参数"prototype"调用F的[[Get]]内部属性的值。
  • 如果Typeproto )是Object,则将obj的[[Prototype]]内部属性设置为proto

但是,如果更改构造函数的prototype属性,它将不会影响以前的实例。

实际上, prototype本身并不特殊,只是[[Construct]]内部方法在创建实例时使用它。

一旦创建了对象,就将其绑定到在创建过程中分配的任何原型?

通常是的。 您可以使用以下方法进行更改,但不建议这样做(由于性能问题):

  • __proto__ :这是Object.prototype的非标准属性,可以用作[[Prototype]]的获取器或设置器。 ECMAScript的6 标准化的IT附件B(附加功能的ECMAScript为Web浏览器)。

  • Object.setPrototypeOf ,这是ECMAScript 6引入的新方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM