JS完美实现对象克隆 (转)

我们知道,在js中,当object作为参数传递到函数中进行处理后,实际上是修改了传入的对象本身(或者说是对象的引用),但很多时候我们并不希望函数去修改我们的这些对象参数,这就需要使用到对象的克隆,我们应该对该对象做一个克隆,然后操作这个克隆的对象,这样就不会影响我们的原对象了。 
    不过在js中并没有对象克隆功能,因此需要我们自己实现,实现方法也不复杂其实,基本上是做一些属性复制,我在网上找了一些,但有些实现并不好,如对于array对象克隆后就成json对象了,并没有保留原来的数组方式。不过最后还是找到了一个很好的克隆函数,完美实现了js对象的克隆功能,不论是Array对象或者是普通的Object,都可以很好的进行克隆,这个函数使用constructor(函数构造器)进行复制。 

具体代码如下: 

Js代码    收藏代码
  1. Object.prototype.Clone = function(){  
  2.     var objClone;  
  3.     if (this.constructor == Object){  
  4.         objClone = new this.constructor();   
  5.     }else{  
  6.         objClone = new this.constructor(this.valueOf());   
  7.     }  
  8.     for(var key in this){  
  9.         if ( objClone[key] != this[key] ){   
  10.             if ( typeof(this[key]) == 'object' ){   
  11.                 objClone[key] = this[key].Clone();  
  12.             }else{  
  13.                 objClone[key] = this[key];  
  14.             }  
  15.         }  
  16.     }  
  17.     objClone.toString = this.toString;  
  18.     objClone.valueOf = this.valueOf;  
  19.     return objClone;   
  20. }   



只须要引用以下代码

Js代码    收藏代码
  1. function clone(myObj){  
  2.   if(typeof(myObj) != 'object'return myObj;  
  3.   if(myObj == nullreturn myObj;  
  4.     
  5.   var myNewObj = new Object();  
  6.     
  7.   for(var i in myObj)  
  8.     myNewObj[i] = clone(myObj[i]);  
  9.     
  10.   return myNewObj;  
  11. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值