在js中,当object作为参数传递到函数中进行处理后,实际上是修改了传入的对象本身(或者说是对象的引用),但很多时候我们并不希望函数去修改我们的这些对象参数,这就需要使用到对象的克隆,我们应该对该对象做一个克隆,然后操作这个克隆的对象,这样就不会影响我们的原对象了。
不过在js中并没有对象克隆功能,因此需要我们自己实现,实现方法也不复杂其实,基本上是做一些属性复制,最后还是找到了一个很好的克隆函数,完美实现了js对象的克隆功能,不论是Array对象或者是普通的Object,都可以很好的进行克隆,这个函数使用constructor(函数构造器)进行复制
用js实现对象克隆最关键的两点就是:var objClone = new this.constructor();和objClone[key] = this[key].Clone();。一个实现相同对象创建,一个实现深度克隆。
Object.prototype.Clone =
function
(){
var
objClone;
if
(
this
.constructor == Object){
objClone =
new
this
.constructor();
}
else
{
objClone =
new
this
.constructor(
this
.valueOf());
}
for
(
var
key
in
this
){
if
( objClone[key] !=
this
[key] ){
if
(
typeof
(
this
[key]) == ‘object’ ){
objClone[key] =
this
[key].Clone();
}
else
{
objClone[key] =
this
[key];
}
}
}
objClone.toString =
this
.toString; //有时候也会把toString,valueOf之类的方法给覆盖
objClone.valueOf =
this
.valueOf;
return
objClone;
}