Javascript can be prototypical
The following JS code can be used to beget (a la Douglas Crockford, with a bit of _prototype spice) and to do a 'real' shallow clone. The object you clone will have the same parent as the cloned object, rather than just inheriting from Object.
This makes javascript work like a 'real' prototypical language (SELF) so we can follow the patterns that that implies.
This makes javascript work like a 'real' prototypical language (SELF) so we can follow the patterns that that implies.
function object(o){
if( !o ) {
o = this;
}
var builder = function(){};
builder.prototype = o;
var result = new builder();
result._prototype = o;
return result;
}
function clone(objectToClone, objectsParent) {
if(!objectToClone) {
objectToClone = this;
}
if(objectToClone._prototype) {
objectsParent = objectToClone._prototype;
}
if(!objectsParent) {
throw "no parent defined for this object";
}
// create new object with prototype
var result = object(objectsParent);
// copy over new stuff
for(var key in objectToClone) {
if( objectToClone.hasOwnProperty(key) ) {
result[key] = objectToClone[key];
}
}
return result;
}
Object.prototype.clone = clone;
Object.prototype.beget = object;
1 Comments:
Well, Today I attended Tiest and Sharons lovely wedding celebration in Brisbane Australia, and it was a beautiful time. They were the picture of beauty and it was a much valued moment.
Apologies for appending this as a comment to a javascript blog, but this was the last entry in Tiests blog and therefore the only place that I could credibly locate this comment.
Congratulations Tiest and Sharon, and I hope you enjoy the best part of a century together.
Love
Rob (and Jenny by proxy)
Post a Comment
<< Home