测试代码:
((_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]);
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