淺拷貝與深拷貝

由于引用類型直接復(fù)制的效果是地址的復(fù)制,只是兩個變量指向了同一塊內(nèi)存嗅绸。

var a = [1,2,3];
var b = a;
b.push[4];
console.log(b);//[1,2,3,4]
console.log(a);//[1,2,3,4]

所以有了淺拷貝和深拷貝沿彭。

淺拷貝

數(shù)組的淺拷貝

var a = [1,2,3];
var b = [];
for(var i in a){
  b[i] = a[i];
}
b.push(4);
console.log(a);//[1,2,3]
console.log(b);//[1,2,3,4]

對象的淺拷貝

var obj1 = {
   a: '1',
   b: '2',
   c: '3'
}
var obj2 = {};
for(i in obj1}{
  obj2[i] = obj1[i];
}
obj2['d'] = 4;
console.log(obj1);//{a: 1,b: 2,c: 3}
console.log(obj2);//{a: 1,b: 2,c: 3, d:4}

但淺拷貝只能實(shí)現(xiàn)一層的拷貝尖滚,無法實(shí)現(xiàn)更深層次的拷貝

function shallowCopy(obj1,obj2){
  for(var key in obj1){
    if(obj1.hasOwnProperty(key)){
       obj2[key] = obj1[key];
    }
  }
}
var obj1 = {
  fruits: ['apple', 'peach'],
  num: 100
};
var obj2 = {};
shallowCopy(obj1,obj2);
obj2.fruits[0] = 'orange';
console.log(obj1.fruits[0]); //orange
console.log(obj2.fruits[0]); //orange

hasOwnProperty方法是為了防止遍歷到數(shù)組或?qū)ο蟮睦^承屬性

淺拷貝還可以通過Object.assign方法來實(shí)現(xiàn)
Object.assign() 方法用于將所有可枚舉屬性的值從一個或多個源對象復(fù)制到目標(biāo)對象喉刘。它將返回目標(biāo)對象。
Object.assign()

    var obj1 = {a:1,b:{c:2,d:3}};
    var obj2 = Object.assign({},obj1);
    obj2.a = 4;
    obj2.b.c = 5;
    console.log(obj1.a);//1
    console.log(obj2.a);//4
    console.log(obj1.b.c);//5
    console.log(obj2.b.c);//5

Array的slice和concat方法不修改原數(shù)組漆弄,只會返回一個淺復(fù)制了原數(shù)組中的元素的一個新數(shù)組睦裳。

深拷貝

通過遞歸調(diào)用淺拷貝的方式來實(shí)現(xiàn)深拷貝

function deepCopy(obj){
        var objArray = Array.isArray(obj)?[]:{};
        if(obj && typeof obj === "object"){
            for(var key in obj){
              if(obj.hasOwnProperty(key)){
                  if(obj[key] && typeof obj[key] === "object"){
                    objArray[key] = deepCopy(obj[key]);
                  }else{
                    objArray[key] = obj[key];
                  }
              }
            }
        }
        return objArray;
    }
    var obj1 = { fruits: ['apple', 'peach'], num: 100 }; 
    var obj2 = deepCopy(obj1);
    obj2.fruits[0] = 'orange'; console.log(obj1.fruits[0]); //apple 
    console.log(obj2.fruits[0]); //orange

還可以通過Json.parse實(shí)現(xiàn)深拷貝

    var obj1 = {a:1,b:{c:2,d:3}};
    var obj2 = JSON.parse(JSON.stringify(obj1));
    obj2.a = 4;
    obj2.b.c = 5;
    console.log(obj1.a);//1
    console.log(obj2.a);//4
    console.log(obj1.b.c);//2
    console.log(obj2.b.c);//5

原理:用JSON.stringify將對象轉(zhuǎn)成字符串撼唾,再用JSON.parse把字符串及解析成對象,一去一來蛛蒙,新的對象產(chǎn)生了,而且對象會開辟新的棧牵祟,實(shí)現(xiàn)深拷貝抖格。

jQuery的extend可以深拷貝也可以淺拷貝

需要注意的是,如果對象比較大雹拄,層級也比較多,深復(fù)制會帶來性能上的問題滓玖。在遇到需要采用深復(fù)制的場景時,可以考慮有沒有其他替代的方案翩肌。在實(shí)際的應(yīng)用場景中,也是淺復(fù)制更為常用摧阅。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绷蹲,一起剝皮案震驚了整個濱河市顾孽,隨后出現(xiàn)的幾起案子比规,更是在濱河造成了極大的恐慌,老刑警劉巖蜒什,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異霎冯,居然都是意外死亡钞瀑,警方通過查閱死者的電腦和手機(jī)沈撞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進(jìn)店門缠俺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來贷岸,“玉大人壹士,你說我怎么就攤上這事偿警。” “怎么了户敬?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵尿庐,是天一觀的道長。 經(jīng)常有香客問我抄瑟,道長,這世上最難降的妖魔是什么皮假? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮贺纲,結(jié)果婚禮上褪测,老公的妹妹穿的比我還像新娘潦刃。我一直安慰自己,他們只是感情好乖杠,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布澄成。 她就那樣靜靜地躺著,像睡著了一般墨状。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上歉胶,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天通今,我揣著相機(jī)與錄音,去河邊找鬼辫塌。 笑死派哲,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的芭届。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼持隧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了屡拨?” 一聲冷哼從身側(cè)響起褥实,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎损离,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體僻澎,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年绷跑,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片砸捏。...
    茶點(diǎn)故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡隙赁,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出伞访,到底是詐尸還是另有隱情,我是刑警寧澤厚掷,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站田绑,受9級特大地震影響抡爹,放射性物質(zhì)發(fā)生泄漏掩驱。R本人自食惡果不足惜冬竟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望涮帘。 院中可真熱鬧,春花似錦焚辅、人聲如沸苟鸯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至砌梆,卻和暖如春贬循,著一層夾襖步出監(jiān)牢的瞬間桃序,已是汗流浹背杖虾。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工媒熊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人嚷往。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓柠衅,卻偏偏與公主長得像,于是被迫代替她去往敵國和親菲宴。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評論 2 353

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

  • 小編已經(jīng)更新了代碼部分付燥,戳這里 一、數(shù)據(jù)類型 數(shù)據(jù)分為基本數(shù)據(jù)類型(String, Number, Boolean...
    grain先森閱讀 2,743評論 2 53
  • 數(shù)據(jù)類型 數(shù)據(jù)分為基本數(shù)據(jù)類型(String,Number漩怎,Boolean,Null勋锤,Undefined,Symb...
    oWSQo閱讀 229評論 0 0
  • 一叁执、數(shù)據(jù)類型 數(shù)據(jù)分為基本數(shù)據(jù)類型(String, Number, Boolean, Null, Undefine...
    grain先森閱讀 95,000評論 13 275
  • 一矮冬、數(shù)據(jù)類型 數(shù)據(jù)分為基本數(shù)據(jù)類型(String, Number, Boolean, Null, Undefine...
    浪里行舟閱讀 795評論 0 4
  • 定義 淺拷貝(shallow copy):只復(fù)制指向某個對象的指針胎署,而不復(fù)制對象本身吆录,新舊對象共享一塊內(nèi)存琼牧。深拷貝...
    YoungEvita閱讀 211評論 0 1