zoukankan      html  css  js  c++  java
  • js中对象的合并

    1 jq中$.extend()

    1
    2
    3
    var obj1= {'a': 1};
    var obj2= {'b': 1};
    var c = $.extend(obj1, obj2);
    4
    console.log(obj1); // {a: 1, b: 1}  obj1已被修改
    5
    //或者 <br>var obj3 = $.extend({}, obj1, obj2) <br>console.log(obj3); //{a: 1, b: 1} 不会改变obj1,obj2

     

    2 遍历赋值

    1
    2
    3
    4
    5
    6
    7
    8
    9
    var obj1={'a':1};
    var obj2={'b':2,'c':3};
    for(var key in obj2){
         if(obj2.hasOwnProperty(key)===true){//此处hasOwnProperty是判断自有属性,用 for in 循环遍历对象的属性时,原型链上的所有属性都将被访问会避免原型对象扩展带来的干扰
               obj1[key]=obj2[key];
    }
     
    console.log(obj1);//{'a':1,'b':2,'c':3};

      

    2.3 Obj.assign() 

      可以把任意多个的源对象自身的可枚举属性拷贝给目标对象,然后返回目标对象。

      Object.assign(target, ...sources)

    1
    2
    3
    //a. 复制一个对象<br>var obj = { a: 1 ,b:2};
    var copyObj = Object.assign({}, obj);
    console.log(copyObj); // { a: 1,b:2 }<br><br>//b.合并多个对象
    1
    2
    3
    4
    5
    6
    7
    var o1 = { a: 1 };
    var o2 = { b: 2 };
    var o3 = { c: 3 };
     
    var obj = Object.assign(o1, o2, o3);
    console.log(obj); // { a: 1, b: 2, c: 3 }
    console.log(o1);  // { a: 1, b: 2, c: 3 }, 且目标对象自身也会改变。 

    4 对象的深拷贝和浅拷贝

    1 浅拷贝

    复制代码
    复制代码
    var obj1={'a':1};
    var obj2={'b':{'b1':22,'b2':33}};
    
    $.extend(obj1, obj2);   //obj1拷贝了obj2的属性
    
    console.log(obj1)  // {'a':1,'b'{'b1':22,'b2':33}}
    console.log(obj1.b.b1)  // 22
    
    obj2.b.b1=44;   //obj2重新赋值
    console.log(obj1.b.b1)  // 44  obj1.b仅拷贝了对象的指引,所以受原obj2的影响
    复制代码
    复制代码

    2 深拷贝

    复制代码
    复制代码
    var obj1={'a':1};
    var obj2={'b':{'b1':22,'b2':33}};
    
    $.extend(true,obj1, obj2);   //第一个参数设为true表示深复制
    
    console.log(obj1)  // {'a':1,'b'{'b1':22,'b2':33}}
    console.log(obj1.b.b1)  // 22
    
    obj2.b.b1=44;   //obj2重新赋值
    console.log(obj1.b.b1)  // 22 obj1拷贝了obj2的所有属性以及值,并不受obj2的影响
    复制代码
    复制代码
  • 相关阅读:
    HTTP断点续传 规格严格
    Java Shutdown 规格严格
    linux 命令源码 规格严格
    JTable调整列宽 规格严格
    linux 多CPU 规格严格
    Hello can not find git path 规格严格
    Kill 规格严格
    拜拜牛人 规格严格
    Swing 规格严格
    Debugging hangs in JVM (on AIX but methodology applicable to other platforms) 规格严格
  • 原文地址:https://www.cnblogs.com/shun1015/p/12297144.html
Copyright © 2011-2022 走看看