JavaScript中如何对一个对象进行深度clone
方法1:
function cloneObject(obj){
if(!obj || 'object' !== typeof obj){
return obj;
}
var o = obj.constructor === Array ? [] : {};
for(var i in obj){
if(obj.hasOwnProperty(i)){
o[i] = typeof obj[i] === "object" ? cloneObject(obj[i]) : obj[i];
}
}
return o;
}
这是网上摘抄的代码,实在有一句看不懂
if(obj.hasOwnProperty(i)){
o[i] = typeof obj[i] === "object" ? cloneObject(obj[i]) : obj[i];
}
这里为何只克隆非原型里面的对象。一个对象的原型属性,该对象也能访问,所以应该连原型也一起克隆。
最后代码为:
function cloneObject(obj){
if(!obj || 'object' !== typeof obj){
return obj;
}
var o = obj.constructor === Array ? [] : {};
for(var i in obj){
//if(obj.hasOwnProperty(i)){
o[i] = typeof obj[i] === "object" ? cloneObject(obj[i]) : obj[i];
//}
}
return o;
}
方法2:
var s = JSON.stringify( obj );
var o = JSON.parse( s );