基本類型和引用類型
學習js的深拷貝和淺拷貝首先要了解js的基本類型和引用類型。
基本類型
基本類型的數據存放在棧內存中,復制的時候是值傳遞,直接把5賦值給了number2
var number1 = 5; var number2 = number1;
引用類型
引用類型的數據存放在堆內存中,棧內存中只存放具體的地址值,把object1賦值給object2的時候是把object1的地址值賦值給了object2,這個時候兩個對象同時指向堆內存中的同一數據。
var object1 = new Object(); var object2 = object1;
深拷貝和淺拷貝的區別
通過遞歸方式實現深拷貝
function deepClone(obj) { var target = {}; for(var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { if (typeof obj[key] === 'object') { target[key] = deepClone(obj[key]); } else { target[key] = obj[key]; } } } return target; }
通過json的方式實現
function (obj) { let tmp = JSON.stringify(obj); let result = JSON.parse(tmp); return result; }
通過Object.create()實現
function deepCopy(obj) { var copy = Object.create(Object.getPrototypeOf(obj)); var propNames = Object.getOwnPropertyNames(obj); propNames.forEach(function(name) { var desc = Object.getOwnPropertyDescriptor(obj, name); Object.defineProperty(copy, name, desc); }); return copy; } var obj1 = { a: 1, b: {bc: 50, dc: 100, be: {bea: 1}} }; var obj2 = deepCopy(obj1); console.log(obj2) obj1.a = 20; console.log(obj1) console.log(obj2) //Object {a: 1, b: Object} //Object {a: 20, b: Object} //Object {a: 1, b: Object}