Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1165529
  • 博文数量: 1310
  • 博客积分: 3980
  • 博客等级: 中校
  • 技术积分: 8005
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-09 22:05
文章分类

全部博文(1310)

文章存档

2011年(1)

2008年(1309)

我的朋友

分类:

2008-11-09 17:41:18


     在js里没有类似JAVA的clone方法,无法实现对对象的克隆,一般使用等号操作符来传递对象,但这样就造成了指针关联问题,修改任何一个对象,其关联的对象也会被改变,但很多时候我们只想得到一个对象的拷贝,而非引用。今日偶就遇到了这个问题,以前还真没有注意过这个,朋友给找了两个方法,感觉写的都不错。只是实现稍有不同,但大体原理是相对的,即逐项复制对象内容
相信这段代码对很多web开发的朋友都会有用。

方法一:定义一个clone方法来实现。

function clone(myObj){
  
if(typeof(myObj) != 'object') return myObj;
  
if(myObj == nullreturn myObj;
  
  
var myNewObj = new Object();
  
  
for(var i in myObj)
    myNewObj[i] 
= clone(myObj[i]);
  
  
return myNewObj;
}


方法二:通过object原型扩展实现

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;
    objClone.valueOf 
= this.valueOf;
    
return objClone; 
}  



Yemoo'S JS Blog 2007-09-25 18:32 发表评论
阅读(1263) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~