简体   繁体   中英

JavaScript: modify prototype of an object's variable?

Here is an object:

var obj = new function(){
    this.prop = {};
}

and I try to do something like:
obj.prop.prototype["new_attr"] = "some_value";

What I'd like to do, is permanently modify obj.prop to contain the new attributes. From what I understood, all "Objects" had the prototype, but JavaScript is telling me prop doesn't have prototype.

Maybe I'm taking the wrong approach (in trying to permanently modify prop ), but I'd at least like to know why the code above doesn't work.

Typically you access the prototype object from the constructor function, but you can get it from an object as well, but not using .prototype .

The unofficial way (not supported in all browsers) to get the prototype object of an object is with the __proto__ property. (I believe it is deprecated in the browsers that support(ed) it).

The official ECMAScript 5 way (also not supported in all browsers) to get the prototype object of an object is to use Object.getPrototypeOf() .

In your case .prop is referencing an object literal, so you already know that the prototype is Object.prototype .

Object.getPrototypeOf( {} ) === Object.prototype;  // true

Note that it is almost always a bad idea to extend Object.prototype .


"Maybe I'm taking the wrong approach (in trying to permanently modify prop), but I'd at least like to know why the code above doesn't work."

If you're just trying to modify the object referenced by .prop , then simply do:

obj.prop.new_attr = "some_value";

You can accomplish what you are trying to do but you need to add the prop object to the constructors prototype:

var Obj = function() {};

Obj.prototype.prop = { bar: 'bar value' };

var obj_1 = new Obj();

console.log(obj_1.prop.bar); //bar value

obj_1.prop.foo = 'foo value';

var obj_2 = new Obj();

console.log(obj_2.prop.foo); //foo value

Because the prop attribute is empty. Before you'll be able to modify object.prop, you need to initialize prop first to a default value.

See the following references: Extending JavaScript Objects and Classes
Introduction to Object-Oriented JavaScript
A re-introduction to JavaScript

HTH. Cheers.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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