91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解JavaScript數組及非數組對象的深淺克隆原理

發布時間:2021-10-19 17:05:50 來源:億速云 閱讀:153 作者:iii 欄目:開發技術

這篇文章主要講解了“如何理解JavaScript數組及非數組對象的深淺克隆原理”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何理解JavaScript數組及非數組對象的深淺克隆原理”吧!

什么是淺克隆、深克隆

淺克隆:直接將存儲在棧中的值賦值給對應變量,如果是基本數據類型,則直接賦值對應的值,如果是引用類型,則賦值的是地址。
深克隆:將數據賦值給對應的變量,從而產生一個與源數據不相干的新數據(數據地址已變化)。即對象各個層級的屬性。
JavaScript中基本數據類型使用符號“=”可以進行克隆,引用數據類型使用符號“=”只是改變了變量的指向,并沒有進行真正的克隆操作。

1.對數組進行克隆

1.1 淺克隆

使用for循環進行淺克隆。

var arr1 = ['demo', 1, 2];
var arr2 = [];
// 數組的淺克隆
for (var i = 0; i < arr1.length; i++) {
    arr2[i] = arr1[i];
}
console.log(arr2);
console.log(arr1 == arr2);

輸出結果:

Array(3)0: "demo"1: 12: 2length: 3[[Prototype]]: Array(0)
false

1.2 深克隆

使用遞歸進行深克隆。

function deepClone(o) {
	var result = [];
	for (var i = 0; i < o.length; i++) {
		result.push(deepClone(o[i]));
	}
	return result;
}

2.對非數組對象進行克隆

2.1 淺克隆

使用for循環進行淺克隆。

var obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] };
var obj2 = {};
// 對象的淺克隆
for (var i in obj1) {
    obj2[i] = obj1[i];
}
console.log(obj2);
console.log(obj1 == obj2);

輸出結果:

{a: 1, b: 2, c: 3, d: Array(3)}
false

2.2 深克隆

使用遞歸進行深克隆。

function deepClone(o) {
	var result = {};
	for (var i in o) {
		result[i] = deepClone(o[i]);
	}
	return result;
}

3.整合深克隆函數

var obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] };
var arr1 = ['demo', 1, 2];
// 深克隆
function deepClone(o) {
    if (Array.isArray(o)) {
        // 是數組
        var result = [];
        for (var i = 0; i < o.length; i++) {
            result.push(deepClone(o[i]));
        }
    } else if (typeof o == 'object') {
        // 非數組,是對象
        var result = {};
        for (var i in o) {
            result[i] = deepClone(o[i]);
        }
    } else {
        // 基本類型值
        var result = o;
    }
    return result;
}
console.log(deepClone(arr1));
console.log(deepClone(obj1));

感謝各位的閱讀,以上就是“如何理解JavaScript數組及非數組對象的深淺克隆原理”的內容了,經過本文的學習后,相信大家對如何理解JavaScript數組及非數組對象的深淺克隆原理這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沁阳市| 乐至县| 增城市| 新巴尔虎右旗| 天祝| 安达市| 连云港市| 苏州市| 临汾市| 平遥县| 天祝| 东兰县| 图们市| 鄂州市| 庐江县| 青海省| 乌拉特前旗| 城步| 盐津县| 海兴县| 桂林市| 建宁县| 织金县| 丰宁| 阜阳市| 新建县| 永嘉县| 韶山市| 临沭县| 万山特区| 宁武县| 伊宁市| SHOW| 本溪| 娄底市| 蛟河市| 霍城县| 固始县| 安国市| 海原县| 鄱阳县|