溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

js中深拷貝和淺拷貝的區(qū)別有哪些

發(fā)布時(shí)間:2021-04-29 10:18:11 來源:億速云 閱讀:604 作者:小新 欄目:編程語言

這篇文章主要介紹js中深拷貝和淺拷貝的區(qū)別有哪些,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

javascript是一種什么語言

javascript是一種動(dòng)態(tài)類型、弱類型的語言,基于對(duì)象和事件驅(qū)動(dòng)并具有相對(duì)安全性并廣泛用于客戶端網(wǎng)頁開發(fā)的腳本語言,同時(shí)也是一種廣泛用于客戶端Web開發(fā)的腳本語言。它主要用來給HTML網(wǎng)頁添加動(dòng)態(tài)功能,現(xiàn)在JavaScript也可被用于網(wǎng)絡(luò)服務(wù)器,如Node.js。

在JavaScript中,變量的類型有基本類型和引用類型兩種類型。我們對(duì)基本類型的復(fù)制操作是對(duì)值進(jìn)行拷貝,對(duì)引用類型的復(fù)制則是拷貝地址。這中間都是通過深拷貝與淺拷貝實(shí)現(xiàn)的。

深拷貝:

1、將數(shù)據(jù)中所有的數(shù)據(jù)賦值過去,無限層級(jí)拷貝,,每一級(jí)別的數(shù)據(jù)都會(huì)拷貝出來;

2、所有元素或?qū)傩跃耆珡?fù)制,與原對(duì)象完全脫離;

3、在堆中重新分配內(nèi)存, 將源對(duì)象的各個(gè)屬性復(fù)制進(jìn)去.;

4、拷貝后,修改拷貝后的對(duì)象,不影響之前的對(duì)象。

function test(obj){
    let _obj = JSON.stringify(obj),
    objClone = JSON.parse(_obj);
    return objClone
}
var tal = {name:'lili'};
Cal=test(tal);
Cal.name = 'kiki';
console.log(tal,Cal);  //{name: "lili"} {name: "kiki"}

淺拷貝:

1、將原有的數(shù)據(jù)賦值過去,只進(jìn)行一層拷貝,深層次的對(duì)象級(jí)別的就拷貝引用;

2、原始類型為值傳遞,對(duì)象類型仍為引用傳遞。;

3、是拷貝引用, 拷貝后的引用都是指向同一個(gè)存放數(shù)據(jù)位置的指針,;

4、拷貝后,修改拷貝后的對(duì)象,會(huì)影響拷貝前的對(duì)象。

var a = [1,2,3,4,5];
var b = a;
a[0] = 6;
console.log(a,b);
//代碼運(yùn)行結(jié)果:a:[6,2,3,4,5]  b:[6,2,3,4,5]

以上是“js中深拷貝和淺拷貝的區(qū)別有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI