• 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为深拷贝,不传为浅拷贝

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

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

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

  • 相关阅读:
    WINCE6.0+S3C6410睡眠和唤醒的实现
    WINCE6.0+S3C6410的触摸屏驱动
    S3C6410的Bootloader的两个阶段BL1和BL2编译相关学习
    amix vim vimrc 3.6 [_vimrc x64 vim (WorkPlace)]配置
    异常的开销
    A C# Reading List by Eric Lippert (ZZ)
    SQL SERVER 2008中定时备份数据库任务的创建与删除
    ASP.NET26个常用性能优化方法
    如何使用四个语句来提高 SQL Server 的伸缩性
    Cookies揭秘 [Asp.Net, Javascript]
  • 原文地址:https://www.cnblogs.com/Ayinger/p/7990188.html
Copyright © 2020-2023  润新知