In my application, I receive a collection of Comments with JSON.
Then, I want to add functions to every item in this collection, so for example if a Comment has comment.first_name
and comment.last_name
, I want to build comment.full_name()
.
So far, I'm doing:
comment.full_name = function() { return this.first_name+" "+this.last_name }
My question is, since there are many comments (and other methods more complex than this one), how could I use prototypes or constructors to add the same function to every item in the collection, without inserting it into each element?
EDIT:
Here is an example of code:
comments = ({"1": {"first_name":"John", "last_name":"Silver"}, "2": {"first_name":"Jack", "last_name":"Sparrow"}})
Now, I'm looking for something that will return
comments[1].name() 开发者_JS百科//=> John Silver
comments[2].name() //=> Jack Sparrow
To answer your direct question, you attach to an object's prototype by literally attaching it to is prototype chain with the prototype
keyword. To attach a function, full_name()
to the comment
object's prototype, you would do something like this:
comment.prototype.full_name = function () {
if (typeof(this.first_name) !== "undefined" && typeof(this.last_name) !== "undefined") {
return this.first_name + " " + this.last_name;
} else {
return ""
}
};
EDIT:
The above code will work for your situation as well. It will attach a property, full_name
to each value in your JSON object. full_name
is a function. It will return a concatenated string containing the current object's first_name
property, a space, and the current object's last_name
property, as long as both of the properties are not undefined
. If one or both of them are, it will return an empty string
.
Given that JSON does not encapsulate any info about type, I'm not sure you could do this generically without adding the method to the object prototype. Whether or not this is desirable is a subject for debate. Once you've got the data from the JSON parser, it's probably better to duck punch the objects one at a time (as it appears you are doing now).
精彩评论