Javascript深度克隆一个对象

 

Javascript中的对像赋值与Java中是一样的,都为引用传递。就是说,在把一个对像赋值给一个变量时,那么这个变量所指向的仍就是原来对

像的地址。那怎么来做呢?答案是“克隆”。

克隆有两种方法:一种是“浅克隆”,一种是“深克隆”(深度克隆)。

浅克隆:基本类型为值传递,对象仍为引用传递。

深克隆(深度克隆):所有元素均完全复制,并于原对象完全独立(原对象的修改不影响新对象)。

深度克隆的代码如下(深克隆去掉递归即为浅克隆):

Object.prototype.clone = function(){
        var o = this.constructor === Array ? [] : {};
        for(var e in this){
                o[e] = typeof this[e] === "object" ? this[e].clone() : this[e];
        }
        return o;
}

使用示例:

obj1 = {name: "flondon", add: "China"};

obj2 = obj1.clone();

注视事项:

网上流传的很多克隆方法都存在克隆不彻底的问题,比如新对象的构造器与原对象的构造器不相同等等,而上面的代码是笔者针对这些问题

重写的代码,并经过大量的测试。(如发现问题请即时留言反馈)

原作者:微米博客

posted @ 2013-10-12 14:37  barbabravo  阅读(251)  评论(0编辑  收藏  举报