1.1 $.extend()
var obj1= {'a': 1}; var obj2= {'b': 1}; var c = $.extend(obj1, obj2); console.log(obj1); // {a: 1, b: 1} obj1已被修改 //或者 var obj3 = $.extend({}, obj1, obj2) console.log(obj3);//{a: 1, b: 1} 不會改變obj1,obj21.2 遍歷賦值
1.2 遍歷賦值
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};
1.3 Obj.assign()
可以把任意多個的源對象自身的可枚舉屬性拷貝給目標對象,然后返回目標對象。 Object.assign(target, ...sources) //a. 復制一個對象<br>var obj = { a: 1 ,b:2}; var copyObj = Object.assign({}, obj); console.log(copyObj); // { a: 1,b:2 }//b.合並多個對象 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 }, 且目標對象自身也會改變。
2 對象的深拷貝和淺拷貝
2.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.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的影響