Skip to content Skip to sidebar Skip to footer

Updating Inherited Property

var foo = {x: 1} var bar = {__proto__: foo} // __proto__ specific to implementation var bar = Object.create(foo) // same result as above with standard API console.log(bar.x) // 1

Solution 1:

Assigning to an object property creates or updates the object's own property, there is no search on the prototype chain for an inherited property.

See ECMAScript Simple Assignment ( = ) §11.13.1.


Solution 2:

It's all about prototypes. bar object has no x property, so when you try to access it, prototypes chain will be involved, and you will get value of foo.x. Then you update foo.x, and while accessing bar.x you will see another value also.

But when you set bar.x, x property will be created in bar object. foo.x is another one so it will stay the same.

And you should avoid using __proto__ in your code. It's browser specific feature (that's why it has underscores in name).


Post a Comment for "Updating Inherited Property"