javascript中的深拷贝和浅拷贝?

来源:互联网 发布:佛山新城网络联系方式 编辑:程序博客网 时间:2024/06/14 17:41

一、jQuery的$.extend 浅拷贝与深拷贝

$.extend( [deep ], target, object1 [, objectN ] );

 deep 类型: Boolean 如果是true,合并成为递归(又叫做深拷贝)。 target 类型: Object  object1 类型: Object 一个对象,它包含额外的属性合并到第一个参数。objectN 类型: Object 包含额外的属性合并到第一个参数。$.extend浅拷贝:var obj1 = {name:xx,age:18,sex:man};var obj2 = {name:cc,age:18};$.extend(obj1,obj2);obj1----->{name:cc,age:18} //被obj2覆盖$.extend深拷贝:var obj1 = {name:xx,age:18,sex:man};var obj2 = {name:cc,age:18};$.extend(true,obj1,obj2);

缺点:不过这有局限性:无法复制函数,原型链没了,对象就是object,所属的类没了

二、浅拷贝

把父对象的属性,全部拷贝给子对象,也能实现继承。
function extendCopy(p) {    var c = {};    for (var i in p) {       c[i] = p[i];    }    c.uber = p;    return c;  }

三、深拷贝
所谓”深拷贝”,就是能够实现真正意义上的数组和对象的拷贝。它的实现并不难,只要递归调用”浅拷贝”就行了。

  function deepCopy(p, c) {    var c = c || {};    for (var i in p) {      if (typeof p[i] === 'object') {        c[i] = (p[i].constructor === Array) ? [] : {};        deepCopy(p[i], c[i]);      } else {         c[i] = p[i];      }    }    return c;  }
总结:浅复制--->就是将一个对象的内存地址的“”编号“”复制给另一个对象。深复制--->实现原理,先新建一个空对象,内存中新开辟一块地址,把被复制对象的所有可枚举的(注意可枚举的对象)属性方法一一复制过来,注意要用递归来复制子对象里面的所有属性和方法,直到子子.....属性为基本数据类型。总结:1,新开辟内存地址,2,递归来刨根复制。