JS----对象的合并与克隆

一. 合并与克隆的差别

1. 克隆是特殊的合并(以空对象作为目标对象,非空对象作为源对象进行合并),克隆要求目标对象与源对象的 constructor相同。

2. 克隆的源对象只有一个,合并的源对象可以是多个。

二. 合并的方法

1.Object.assign():

例:var obj1 ={

      m : 1,

      n : 2,

      j : {

           r : {

              h : 2

            },

           p : 4 } ,

      p : 1

   }

       var obj2 ={ m : 2 , n : undefined, j : { h : 2 ,o:  3}}

       var obj3 = Object.assign(obj1,obj2);

结果:obj1 = { m : 2,n : undefined, j : { h : 2, o : 3 }, p : 1 };

           obj2 ={ m : 2 , n : undefined, j : { h : 2, o : 3 } };

           obj3 ={ m : 2 , n : undefined, j : { h : 2, o : 3 }, p : 1 };

注意:1).  目标对象自身也会变  obj1===obj3

           2). 此方法为浅合并

           3). undefined参与合并

           4). 原型不属性参与合并

 2. $.extend:

情况一:

例:var obj1 ={ m : 1, n : 2, j : { r : { h : 2 }, p : 4 }, p : 1 }

       var obj2 ={ m : 2, n : undefined, j : { h : 2, o : 3 } }

       var obj3 = $.extend(obj1,obj2);

结果:obj1 = { m : 2, n : 2, j : { h : 2, o : 3 }, p : 1 };

           obj2 ={ m : 2, n : undefined, j : { h : 2, o : 3 } };

           obj3 ={ m : 2, n : 2, j : { h : 2, o : 3 }, p : 1 };

注意:1).  目标对象自身也会变  obj1===obj3

           2). 此方法为浅合并

           3). undefined不参与合并

           4). 原型不属性参与合并

情况二:

例:var obj1 ={ m : 1, n : 2, j : { r : { h : 2 }, p : 4 }, p : 1 }

       var obj2 ={ m : 2, n : undefined, j : { h : 2, o : 3 } }

       var obj4 = $.extend({},obj1,obj2);

结果:obj1 = { m : 1, n : 2, j : { r : { h : 2 }, p : 4 }, p : 1 };

           obj2 ={ m : 2, n : undefined, j : { h : 2, o : 3 } };

           obj3 ={ m : 2, n : 2, j : { h : 2, o : 3 }, p : 1 };

注意:1).  此方法为浅合并

           2). undefined不参与合并

           3). 原型不属性参与合并

情况三:

例:var obj1 ={ m:1,n:2,j:{r:{h:2},p:4},p:1}

       var obj2 ={m:2,n:undefined,j:{h:2,o:3}}

       var obj3 = $.extend(true,obj1,obj2);

结果:obj1 = {m:2,n:2,j:{h:2,o:3,r:{h:2},p:4},p:1};

           obj2 ={m:2,n:undefined,j:{h:2,o:3}};

           obj3 ={m:2,n:2,j:{h:2,o:3,r:{h:2},p:4},p:1};

注意:1).  目标对象自身也会变  obj1===obj3

           2). 此方法为深合并

           3). undefined不参与合并

           4). 原型不属性参与合并

3. 遍历赋值法 

思路:将obj2中存在的属性但obj1不存在的属性赋值给obj1。

步骤:1). 遍历obj2中属性。

           2). 判断obj1不存在此属性

           3). 将次值赋给obj1

var extentObj = function(obj1,obj2){

    for(let key in obj2){

     if(obj2.hasOwnProperty(key) && (!obj1.hasOwnProperty(key))){

    obj1[key] = obj2[key]

   }

  }

}

 三. 克隆的方法

1. JSON.parse(JSON.stringify()):

    1). 先将对象变为字符串,然后再变为json对象,防止对象的指针指向问题,为深拷贝

     2). undefined 和 function 类型的属性会被忽略,而 Date 类型的属性则会被转换为字符串

 2. $.extend:

    传true为深拷贝,不传为浅拷贝

注意:深拷贝与浅拷贝的区别

浅拷贝直接把引用地址原样拿来,此时,不管源对象还是目标对象,修改引用属性后另一个对象的同名属性都会受到影响。

深拷贝则会递归地在目标对象上创建值,目标对象和源对象之间将完全独立

原文地址:https://www.cnblogs.com/Ayinger/p/7990188.html