關(guān)于JS的深淺拷貝

JS關(guān)于基礎(chǔ)類(lèi)型和引用類(lèi)型的數(shù)據(jù)請(qǐng)點(diǎn)擊:JS數(shù)據(jù)類(lèi)型
請(qǐng)充分理解之后再來(lái)看這篇文章哦~

基本類(lèi)型的拷貝

先來(lái)看一段非常經(jīng)典的代碼

var a = 1;
var b = a;
a = 200;
console.log(a);      //200
console.log(b);      //1

我們應(yīng)該知道基本類(lèi)型“按值傳遞”蹋半,引用類(lèi)型“按引用傳遞”募书,數(shù)值作為基本類(lèi)型是保存在棧內(nèi)存中晕窑,可以直接拿來(lái)用的,賦值是什么那么之后就一直是什么,不會(huì)受到傳遞元素的改變帶來(lái)的影響,所以這里就不難理解上面的代碼得到的值的原因了。

引用類(lèi)型的拷貝

簡(jiǎn)單說(shuō)他爸,引用類(lèi)型是生成一個(gè)指針保存的堆內(nèi)存中,當(dāng)給引用類(lèi)型賦值時(shí)果善,我們寫(xiě)的內(nèi)容是在棧內(nèi)存中诊笤,也就是說(shuō)我們拿到的其實(shí)是一個(gè)指針(不會(huì)直接拿到棧內(nèi)存中的內(nèi)容)。這個(gè)指針是指向棧內(nèi)存中這個(gè)引用類(lèi)型的代碼巾陕。
提到拷貝涉及到的兩種拷貝類(lèi)型:深拷貝和淺拷貝

淺拷貝

淺拷貝針對(duì)對(duì)象中的基本類(lèi)型的值生效讨跟,但是對(duì)引用類(lèi)型中還有引用類(lèi)型的情況就會(huì)失效。

var a = {
  name:"mary",
  age:20,
  hobby:"eat"
}

function shadowCopy(obj){
  var newObj = {};
  for(var key in obj){
     newObj[key] = obj[key];
  }
  return newObj;
}
var b = shadowCopy(a);
console.log(b)

這是得到的就是一個(gè)和a完全一樣的對(duì)象惜论,這個(gè)函數(shù)就是一個(gè)淺拷貝函數(shù)许赃。

深拷貝

深拷貝是針對(duì)對(duì)象中還有引用類(lèi)型的情況,使用深拷貝可以使新創(chuàng)建的對(duì)象和原來(lái)的完全脫離關(guān)系

var a = {
  name:"mary",
  age:20,
  friend:{
    name:"哈哈",
    age:19,
    hobby:"eat"
  }
}

function deep(obj){
  var newobj = {};
  for(var key in obj){
    if(obj.hasOwnProperty(key)){
      if(typeof obj[key] === "number" || typeof obj[key] === "string" || typeof obj[key] === "boolean" || obj[key] === undefined || obj[key] === null){
         newobj[key] = obj[key];
      }else{
        newobj[key] = deep(obj[key]);
      }
    }
  }
  return newobj;
}
var b = deep(a);
a.friend.age = 29;        //此處修改了a對(duì)象中的某個(gè)值馆类,但是經(jīng)過(guò)函數(shù)處理混聊,b里面的這個(gè)值不會(huì)發(fā)生改變
console.log(a);
console.log(b);

里面的hasOwnProperty這個(gè)屬性請(qǐng)參考 MDN的解釋

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子句喜,更是在濱河造成了極大的恐慌预愤,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咳胃,死亡現(xiàn)場(chǎng)離奇詭異植康,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)展懈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)销睁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人存崖,你說(shuō)我怎么就攤上這事冻记。” “怎么了来惧?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵冗栗,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我供搀,道長(zhǎng)隅居,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任葛虐,我火速辦了婚禮胎源,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘挡闰。我一直安慰自己乒融,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布摄悯。 她就那樣靜靜地躺著,像睡著了一般愧捕。 火紅的嫁衣襯著肌膚如雪奢驯。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,245評(píng)論 1 299
  • 那天次绘,我揣著相機(jī)與錄音瘪阁,去河邊找鬼。 笑死邮偎,一個(gè)胖子當(dāng)著我的面吹牛管跺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播禾进,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼豁跑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了泻云?” 一聲冷哼從身側(cè)響起艇拍,我...
    開(kāi)封第一講書(shū)人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤狐蜕,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后卸夕,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體层释,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年快集,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了贡羔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡个初,死狀恐怖治力,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情勃黍,我是刑警寧澤宵统,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站覆获,受9級(jí)特大地震影響马澈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜弄息,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一痊班、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧摹量,春花似錦涤伐、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至睦尽,卻和暖如春器净,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背当凡。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工山害, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沿量。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓浪慌,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親朴则。 傳聞我的和親對(duì)象是個(gè)殘疾皇子权纤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1.寫(xiě)一個(gè)NSString類(lèi)的實(shí)現(xiàn) +(id)initWithCString:(c*****t char *)nu...
    韓七夏閱讀 3,765評(píng)論 2 37
  • Java8張圖 11、字符串不變性 12、equals()方法妖碉、hashCode()方法的區(qū)別 13涌庭、...
    Miley_MOJIE閱讀 3,701評(píng)論 0 11
  • *面試心聲:其實(shí)這些題本人都沒(méi)怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個(gè)offer,總結(jié)起來(lái)就是把...
    Dove_iOS閱讀 27,139評(píng)論 30 470
  • __block和__weak修飾符的區(qū)別其實(shí)是挺明顯的:1.__block不管是ARC還是MRC模式下都可以使用,...
    LZM輪回閱讀 3,309評(píng)論 0 6
  • 307欧宜、setValue:forKey和setObject:forKey的區(qū)別是什么坐榆? 答:1, setObjec...
    AlanGe閱讀 1,547評(píng)論 0 1