對象的深拷貝和淺拷貝

數(shù)組的深淺拷貝

在使用JavaScript對數(shù)組進(jìn)行操作的時候,我們經(jīng)常需要將數(shù)組進(jìn)行備份心包,事實證明如果只是簡單的將它賦予其他變量类咧,那么我們只要更改其中的任何一個,然后其他的也會跟著改變,這就導(dǎo)致了問題的發(fā)生痕惋。

淺拷貝
var arr = ["One","Two","Three"];
console.log(arr);//["One", "Two", "Three"]

var arrto = arr;
arrto[1] = "test";
console.log("數(shù)組的原始值:" + arr + "<br />");//Export:數(shù)組的原始值:One,test,Three
console.log("數(shù)組的新值:" + arrto + "<br />");//Export:數(shù)組的新值:One,test,Three

像上面的這種直接賦值的方式就是淺拷貝区宇,很多時候,這樣并不是我們想要得到的結(jié)果值戳,其實我們想要的是arr的值不變议谷,不是嗎?

深拷貝

方法一:js的slice函數(shù)

var arr = ["One","Two","Three"];

var arrtoo = arr.slice(0);
arrtoo[1] = "set Map";
document.writeln("數(shù)組的原始值:" + arr + "<br />");//Export:數(shù)組的原始值:One,Two,Three
document.writeln("數(shù)組的新值:" + arrtoo + "<br />");//Export:數(shù)組的新值:One,set Map,Three

方法二:js的concat方法

var arr = ["One","Two","Three"];

var arrtooo = arr.concat();
arrtooo[1] = "set Map To";
document.writeln("數(shù)組的原始值:" + arr + "<br />");//Export:數(shù)組的原始值:One,Two,Three
document.writeln("數(shù)組的新值:" + arrtooo + "<br />");//Export:數(shù)組的新值:One,set Map To,Three

Obj的深淺拷貝

直接引用堕虹,修改了原對象

let conf = {
  adapter:'sqlite',
  db: {
    sqlite:{
      name:'xxx.sqlite'
    },
    mysql:{
      name:'xxx',
      username:'work',
      passwd:'******'
    }
  }
}

//直接引用
let conf2 =conf;
conf2.adapter = 'mysql';
console.log(conf);
console.log(conf2)

淺拷貝

let conf = {
  adapter:'sqlite',
  db: {
    sqlite:{
      name:'xxx.sqlite'
    },
    mysql:{
      name:'xxx',
      username:'work',
      passwd:'******'
    }
  }
}

//淺拷貝
let copied = Object.assign({},conf);
copied.adapter = 'mysql';
console.log(conf.adapter);//"sqlite"
console.log(copied.adapter);//"mysql"
copied.db.sqlite.name ='yyy.sqlite';
//多級屬性無法被拷貝卧晓,而是引用
console.log(conf.db.sqlite.name);//"yyy.sqlite"
console.log(copied.db.sqlite.name);//"yyy.sqlite"

所以使用深拷貝

let conf = {
 adapter:'sqlite',
 db: {
   sqlite:{
     name:'xxx.sqlite'
   },
   mysql:{
     name:'xxx',
     username:'work',
     passwd:'******'
   }
 }
}

//深拷貝
function deepCopy(des,src) {
 for(var key in src) {
   let prop = src[key];
   if (typeof prop === 'object') {
     des[key] = des[key]||{}; //判斷目標(biāo)對象是否有自身的key
     deepCopy(des[key],prop);
   }else{
     des[key] = src[key];
   }
 }
 return des;
}

let obj1= {
 db:{
   c:"name"
 },
 ad:'ad'
}


let deepCopied = deepCopy(obj1,conf);
let deepCopied2= deepCopy({},conf);
console.log(deepCopied);
console.log(deepCopied2);
deepCopied.db.sqlite.name = 'zzz.sqlite';
console.log([deepCopied.db.sqlite.name,conf.db.sqlite.name]);

//console
[object Object] {
 ad: "ad",
 adapter: "sqlite",
 db: [object Object] {
   c: "name",
   mysql: [object Object] { ... },
   sqlite: [object Object] { ... }
 }
}
[object Object] {
 adapter: "sqlite",
 db: [object Object] {
   mysql: [object Object] { ... },
   sqlite: [object Object] { ... }
 }
}
["zzz.sqlite", "xxx.sqlite"]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市赴捞,隨后出現(xiàn)的幾起案子逼裆,更是在濱河造成了極大的恐慌,老刑警劉巖赦政,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胜宇,死亡現(xiàn)場離奇詭異,居然都是意外死亡恢着,警方通過查閱死者的電腦和手機(jī)桐愉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來然评,“玉大人仅财,你說我怎么就攤上這事狈究⊥胩剩” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵抖锥,是天一觀的道長亿眠。 經(jīng)常有香客問我,道長磅废,這世上最難降的妖魔是什么纳像? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮拯勉,結(jié)果婚禮上竟趾,老公的妹妹穿的比我還像新娘。我一直安慰自己宫峦,他們只是感情好岔帽,可當(dāng)我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著导绷,像睡著了一般犀勒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天贾费,我揣著相機(jī)與錄音钦购,去河邊找鬼。 笑死褂萧,一個胖子當(dāng)著我的面吹牛押桃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播导犹,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼怨规,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了锡足?” 一聲冷哼從身側(cè)響起波丰,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎舶得,沒想到半個月后掰烟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡沐批,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年纫骑,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片九孩。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡先馆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出躺彬,到底是詐尸還是另有隱情煤墙,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布宪拥,位于F島的核電站仿野,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏她君。R本人自食惡果不足惜脚作,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望缔刹。 院中可真熱鬧球涛,春花似錦、人聲如沸校镐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽灭翔。三九已至魏烫,卻和暖如春辣苏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背哄褒。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工稀蟋, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人呐赡。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓退客,卻偏偏與公主長得像,于是被迫代替她去往敵國和親链嘀。 傳聞我的和親對象是個殘疾皇子萌狂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,492評論 2 348

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