JavaScript 原生js深拷貝的實(shí)現(xiàn)

這次的學(xué)習(xí)深拷貝參考了子匠大大的文章:《JavaScript中對(duì)象的深拷貝》

JSON.parse()&JSON.stringify()

通過JSON的兩個(gè)方法使對(duì)象重新構(gòu)造成新的對(duì)象實(shí)現(xiàn)深拷貝,它的問題在于會(huì)丟棄對(duì)象的constructor,同時(shí)必須保證處理的對(duì)象為能夠被json數(shù)據(jù)結(jié)構(gòu)表示,比如Number,String,Boolean,Array,扁平對(duì)象,否則無(wú)法處理沮稚。

function deepCopy(initalObject){
    var finalObject = {}
    try {
        finalObject = JSON.parse(JSON.stringify(initalObject))
    }
    return finalObject
}

遞歸的方法

function deepCopy(initalObject,finalObject){
  var finalObject = finalObject || {}
  for(var key in initalObject){
    if(typeof initalObject[key] === "object"){
      finalObject[key] = (initalObj[key].constructor === Array) ? [] : {}  // 區(qū)分是數(shù)組還是對(duì)象
      arguments.callee(initalObject[key],finalOjbect[key]) //調(diào)用自身函數(shù)方法
    }else{
      finalObject[key] = initalObject[key]
    }
  }
  return finalObject
}

參考文章中,提到相互引用對(duì)象死循環(huán)的情況,則有下面的優(yōu)化.

function deepCopy(initalObject,finalObject){
  var finalObject = finalObject || {}
  for(var key in initalObject){
    var tempProperty = initalObject[key]
    if(tempProperty === initalObject){
      continue //
      當(dāng)自身屬性引用自己的時(shí)候,跳過執(zhí)行,不拷貝,避免相互引用導(dǎo)致內(nèi)存溢出的情況
    }
    if(typeof initalObject[key] === "object"){
      finalObject[key] = (initalObject[key].constructor === Array) ? [] : {}  //區(qū)分構(gòu)造函數(shù)
      arguments.callee(initalObject[key],finalObject[key]) //調(diào)用自身函數(shù)方法
    }else{
      finalObject[key] = initalObject[key]
    }
  }
  return finalObject
}

ps:參考文章中的方法有誤,應(yīng)該是if(prop === initalObj){continue}

Object.create()

使用object.create()的問題在于避開了遞歸,但是數(shù)組則無(wú)法做下一步處理,如果是一些特殊的構(gòu)造函數(shù)實(shí)例比如正則對(duì)象同樣存在這個(gè)問題

function deepCopy(initalObject,finalObject){
  var finalObject = finalObject || {} 
  // 處理未輸入新對(duì)象的情況
  for(var key in initalObject){
    if(initalObject[key] === initalObject){
      continue
    }
    if(typeof initalObject[key] === "object"){
      finalObject[key] = (initalObject[key].constructor === Array) ? [] : Object.create(initalObject[key])  //通過Object.create()方法構(gòu)造新的對(duì)象
    }else{
      finalObject[key] = initalObject[key]
    }
  }
  return finalObject
}

參考文章:
http://www.dengzhr.com/js/1180
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Functions/arguments/callee

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末难咕,一起剝皮案震驚了整個(gè)濱河市媚朦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌吹埠,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異实蓬,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)吊履,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門安皱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人艇炎,你說(shuō)我怎么就攤上這事酌伊。” “怎么了缀踪?”我有些...
    開封第一講書人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵居砖,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我驴娃,道長(zhǎng)奏候,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任唇敞,我火速辦了婚禮蔗草,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘厚棵。我一直安慰自己蕉世,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開白布婆硬。 她就那樣靜靜地躺著狠轻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪彬犯。 梳的紋絲不亂的頭發(fā)上向楼,一...
    開封第一講書人閱讀 49,837評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音谐区,去河邊找鬼湖蜕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛宋列,可吹牛的內(nèi)容都是我干的昭抒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼灭返!你這毒婦竟也來(lái)了盗迟?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤熙含,失蹤者是張志新(化名)和其女友劉穎罚缕,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體怎静,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡邮弹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蚓聘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片腌乡。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖或粮,靈堂內(nèi)的尸體忽然破棺而出导饲,到底是詐尸還是另有隱情捞高,我是刑警寧澤氯材,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站硝岗,受9級(jí)特大地震影響氢哮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜型檀,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一冗尤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胀溺,春花似錦裂七、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至无埃,卻和暖如春徙瓶,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背嫉称。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工侦镇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人织阅。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓壳繁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子闹炉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

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