首先來理解一下深拷貝與淺拷貝的概念
我們談到深拷貝與淺拷貝都是針對于物件或者陣列這種復雜資料型別,也就是參考資料型別
淺拷貝:只是對記憶體地址的拷貝,跟拷貝前指向的是同一塊記憶體;
深拷貝:既拷貝了記憶體地址,又拷貝了資料內容,是在堆記憶體中重新開辟了一塊存盤空間.
記憶體分為堆疊記憶體跟堆記憶體,對于基本資料型別會被直接存盤到堆疊記憶體中,常用的比如:undefined、null、number、boolean、string,而對于陣列,物件這種參考資料型別,他們的真實資料內容會被存在堆記憶體中,在堆疊記憶體中只會存盤他們在堆記憶體中的地址
OK,話不多說,直接上代碼:
/**
* 深拷貝
* @param {*} source
* @returns
*/
function deepClone(source) {
//初始化物件, 陣列的構造方法指向 Array, 物件的構造方法指向 Object
const targetObj = source.constructor === Array ? [] : {};
//回圈遍歷
for (const key in source) {
//判斷source本身是否有該屬性
if (Object.hasOwnProperty.call(source, key)) {
//假如該屬性值是object型別,那么需要遞回一層
if (source[key] && typeof source[key] === "object") {
targetObj[key] = deepClone(source[key]);
} else {
//基本資料型別直接賦值
targetObj[key] = source[key];
}
}
}
return targetObj;
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/510739.html
標籤:其他
上一篇:NFC讀寫器與瀏覽器Chrome
