I tried to exactly clone an object in javascript. I know the following solution using jquery:
var newObject = jQuery.extend({}, oldObject);
// Or
var newObject = jQuery.extend(true, {}, oldObject);
but the problem with that is, that the objects type gets lost:
var MyClass = function(param1, param2) {
alert(param1.a + param2.a);
};
var myObj = new MyClass({a: 1},{a: 2});
var myObjClone = jQuery.extend(true, {}, myObj);
alert(myObj instanceof MyClass); // => true
alert(myObjClone instanceof MyClass); // => false
Is there any solution to get true on the second alert?
jQuery.extend is not expecting you to use the instanceof operator. It is doing a gloriously complicated copy, and not a true clone. Looping through the elements is not enough. Also, calling the constructor isn’t best cause you’ll loose your arguments. Try this:
Be aware that since your prototype now points back to the origional (myObj), any changes to myObj will reflect in myObjClone. Javascript’s prototypal inheritance is kinda tricky. You need to be sure that your new object has the correct prototype, and hence the correct constructor.
Admitadly, Javascript makes my head hurt. Still, I think I’m reading this right, from the ECMAScript language spec:
This person seems to understand the concept much better than I do. K, I’m going back to java now where I swim more than I sink 🙂 .