使用遍历的方法实现对对象的深拷贝

前端之家收集整理的这篇文章主要介绍了使用遍历的方法实现对对象的深拷贝前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

测试代码

((_t = (o)) == "object" ? o== && "null" || Object.prototype.toString.call(o).slice(8,-1( p (getType(source[p])=="array"||getType(source[p])=="object"=getType(source[p])=="array"?=<span style="color: #0000ff;">var test=<span style="color: #000000;">{
a:
"ss"<span style="color: #000000;">,b:
"dd"<span style="color: #000000;">,c:[
{d:
"css",e:"cdd"<span style="color: #000000;">},{
m:
"ff"<span style="color: #000000;">,n:[
{kk:
"11",jj:"22"<span style="color: #000000;">},{ll:
"44"<span style="color: #000000;">}
]
}
]
};

<span style="color: #0000ff;">var test1=<span style="color: #000000;">{};
extend(test1,test);
console.log(test);
console.log(test1);
test1.c[1].n[0].kk="change"; <span style="color: #008000;">//<span style="color: #008000;">改变test1的c属性对象的d属性
<span style="color: #000000;">console.log(test);
console.log(test1);
console.log(test.c[1].n[0<span style="color: #000000;">]);
console.log(test1.c[1].n[0]);

测试结果

 

 从测试结果可以看到,通过使用这个遍历的方法,成功将对象test深拷贝复制一份,得到test1。并且更改test1对象的属性,并不会对test对象产生影响。


参考文章:http://www.cnblogs.com/Loofah/archive/2012/03/23/2413665.html

猜你在找的JavaScript相关文章