成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

理解JavaScript中的淺拷貝與深拷貝

開發(fā) 后端
本文給大家介紹JavaScript中的淺拷貝與深拷貝

 淺拷貝
在使用JavaScript對數(shù)組進(jìn)行操作的時候,如果只是簡單的將它賦予其他變量,那么我們只要更改其中的任何一個,然后其他的也會跟著改變,這就導(dǎo)致了問題的發(fā)生

var arr = ['aa','bb','cc'];

var arr2 = arr;

arr2[0] = '新來的';

console.log(arr);//輸出 '新來的','bb','cc'

由此可見對數(shù)組arr2進(jìn)行修改時,而arr內(nèi)數(shù)據(jù)也會隨之改變。這種直接賦值的方式就是淺拷貝現(xiàn)象。那到底是為什么呢?

因?yàn)镴avaScript存儲對象都是存地址的,所以淺復(fù)制會導(dǎo)致 arr 和 arr2 指向同一塊內(nèi)存地址,大概的示意圖如下。

所以當(dāng)修改arr2中的數(shù)據(jù)時,由于arr也指向此處,所以arr的數(shù)據(jù)也就被“修改了”。

深拷貝
一般都是開辟一塊新的內(nèi)存地址,將原對象的各個屬性逐個復(fù)制出去。如下圖所示


所以當(dāng)修改arr2中的數(shù)據(jù)時,由于arr與arr2地址不同,所以arr的數(shù)據(jù)還是原來的。

數(shù)組的深拷貝
var arr = ['aa','bb','cc'];

var arr2 = arr.slice(0);

arr2[0] = "新來的";

console.log(arr);//輸出:數(shù)組的原始值:'aa','bb','cc'

console.log(arr2);//輸出:數(shù)組的新值:'新來的','bb','cc'

Json的深拷貝
在這里利用JSON下的兩個方法來實(shí)現(xiàn)對象的深拷貝。

var json = {a:12,b:5};

var str = JSON.stringify(json);//這里將json內(nèi)的數(shù)據(jù)轉(zhuǎn)換成一個字符串存起來

var json2 = JSON.parse(str);//這里將字符串的內(nèi)容"還原"成原來的"面目"

console.log(json2);//輸出 {a:12,b:5}

總結(jié)
其實(shí)在js中還有很多方法能進(jìn)行深拷貝,例如利用數(shù)組下的cancat方法;對Json進(jìn)行遍歷然后給新的對象等等。

補(bǔ)充
以上只考慮了純數(shù)組或者純對象(json串)的情況,當(dāng)互相嵌套時確實(shí)有問題,經(jīng)過查閱資料找到了一個函數(shù)

function cloneObject( obj, deep ){

if ( obj === null || obj === undefined || typeof (obj) !== 'object' ){

return obj;

}

var deep = !!deep;

var cloned = null;

if ( obj.constructor === Array ){

if ( deep === false ) return obj;

cloned = [];

for ( var i in obj ){

cloned.push( cloneObject( obj[i], deep ) );

}

return cloned;

}

cloned = {};

for ( var i in obj ){

cloned[i] = deep ? cloneObject( obj[i], true ) : obj[i];

}

return cloned;

}

var arr = [1, 3, 5, {a: 5}]

var newArr =cloneObject(arr,true);

newArr[3].a = 9

console.log(arr, newArr)

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2021-07-16 12:33:24

Javascript深拷貝淺拷貝

2018-05-10 14:20:18

前端JavaScript深拷貝

2024-03-15 15:03:23

2023-05-17 08:42:46

深拷貝Golang

2009-05-19 17:28:44

深拷貝淺拷貝clone()

2020-06-23 08:41:47

JavaScript開發(fā)技術(shù)

2025-04-27 09:45:58

JavaScript深拷貝淺拷貝

2018-09-26 14:37:17

JavaScript前端編程語言

2021-01-08 06:15:09

深拷貝淺拷貝寫時拷貝

2024-04-17 09:01:08

Python深拷貝淺拷貝

2017-08-16 13:30:05

Java深拷貝淺拷貝

2017-05-24 11:54:55

Javascript深拷貝

2022-11-07 11:37:27

深拷貝淺拷貝底層

2019-02-25 08:58:16

Python深拷貝淺拷貝

2024-02-05 22:56:16

C++拷貝開發(fā)

2021-09-27 11:07:11

深拷貝淺拷貝內(nèi)存

2022-07-26 08:07:03

Python淺拷貝深拷貝

2020-08-03 08:24:26

原型模式拷貝

2023-09-22 12:21:33

Python深拷貝淺拷貝

2023-05-08 09:00:46

JSON深拷貝對象
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 色屁屁在线观看 | 欧美激情a∨在线视频播放 成人免费共享视频 | 色欧美片视频在线观看 | 日本一区二区三区精品视频 | 欧美日韩国产一区二区三区 | 久久国| 欧美日韩福利 | 美女黄18岁以下禁止观看 | 欧美一区二区三区四区在线 | 日韩精品一区二区三区 | 久久久久久亚洲精品 | 91福利网 | 最新高清无码专区 | 手机在线观看 | 一区二区三区观看视频 | 欧美激情a∨在线视频播放 成人免费共享视频 | 国产精品久久亚洲 | a视频在线 | 草久久久 | 一级片免费视频 | 国产视频一区二区三区四区五区 | 欧美日韩综合视频 | 波多野吉衣久久 | 国产精品久久久久久久久久 | 国产午夜精品一区二区三区嫩草 | 欧美一区久久 | 天天干干 | 91视频入口| 在线观看视频91 | 在线播放国产视频 | 色必久久 | av片免费 | 国产成人精品久久二区二区91 | 国产日韩精品一区二区 | 九色91视频 | 国产精品视频不卡 | 国产免费一区二区三区 | 久久久99精品免费观看 | 精品欧美乱码久久久久久1区2区 | 精品亚洲一区二区三区 | 日韩三区|