日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳細分析JavaScript中的深淺拷貝

瀏覽:128日期:2023-10-13 09:43:47

在說JS中深淺拷貝之前,我們需要對JS中的數據類型有所了解,分為基本數據類型與引用數據類型,對于基本數據類型并沒有深淺拷貝的說法,深淺拷貝主要針對引用數據類型。

一、淺拷貝

淺拷貝只復制了引用,并沒有復制值。在JS中最簡單的淺拷貝就是利用“=”賦值操作符來實現。

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’}, fun:function(){ console.log(’fun’) }}var obj2 = obj1obj2.a = 666 /* 修改obj2的值,obj1的值也隨之改變 */console.log(obj1) /* {a: 666, b: Array(3), c: {…}, fun: ƒ} */

上述代碼中,我們修改obj2的值,obj1的值也隨之發生了改變,使用”=“只實現了淺拷貝。

二、深拷貝

深拷貝是對目標的完全拷貝,進行深拷貝后的兩個值互不影響。

1. 利用JSON.stringify與JSON.parse方法

JSON.stringify將一個JavaScript值轉換為JSON字符串;

JSON.parse將一個JSON字符串轉換為JavaScript值。

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’},}var obj2 = JSON.parse(JSON.stringify(obj1))obj2.a = 12console.log(obj1) /* {a: 1, b: Array(3), c: {…}} */

修改obj2的值并沒有影響到obj1中的屬性值,顯然,我們利用JSON.parse與JSON.stringify實現了深拷貝。

但是,真的可以這么簡單的實現嗎?我們來看看下面的例子!

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’}, fun:function(){ console.log(’fun’) }}var obj2 = JSON.parse(JSON.stringify(obj1))obj2.a = 12console.log(obj1) /* {a: 1, b: Array(3), c: {…}, fun: ƒ} */console.log(obj2) /* {a: 12, b: Array(3), c: {…}} */

轉換后的obj2中沒有了fun這個屬性,這是由于在利用JSON.stringify轉換過程中,忽略了undefined、function、symbol。顯然,當我們的對象中出現這些類型的屬性時無法利用該方法實現深拷貝。

2. 遞歸

function deepClone(source){ if(!isObject(source)) return source var newObj = source instanceof Array? []:{} for(let key in source){if(source.hasOwnProperty(key)){ newObj[key] = isObject(source[key])?deepClone(source[key]):source[key] } } return newObj}function isObject(x) { return typeof x === ’object’ && x != null}

測試一下上述方法:

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’}, fun:function(){console.log(’fun’) }}var obj2 = deepClone(obj1)obj2.a = 12console.log(obj1) /* {a: 1, b: Array(3), c: {…}, fun: ƒ} */

通過例子可以看到,我們修改了obj2中a屬性的值,但是并沒有影響到obj1中的a屬性值。通過遞歸我們可以實現深拷貝!

注意:上述方法未解決循環引用的問題。

var obj1 = {}obj1.a = obj1var obj2 = deepClone(obj1) /* 報錯,棧溢出 */console.log(obj2)

關于如何解決循環引用問題以及實現Symbol類型拷貝,稍后完善。

三、其他拷貝方法

1. 數組中的concat()和slice()方法

我們知道數組中有兩個方法concat和slice可以完成復制數組,并且返回新數組。以concat為例。

var arr = [1,2,3]var arr2 = arr.concat()arr2[2]=4console.log(arr) /* [1, 2, 3] */console.log(arr2) /* [1, 2, 4] */

改變arr2的值,并沒有影響到arr的值,這是實現了數組的深拷貝嗎,先不急于下結論,一起看看下面的例子再來分析:

var arr = [1,2,3,[4,5,6],{a:7}]var arr2 = arr.concat()arr2[3] = 444arr2[4].a=8console.log(arr) /* [1,2,3,[4,5,6],{a:8}] */console.log(arr2) /* [1,2,3,444,{a:8}] */

我們直接修改arr2[3],并沒有引起arr的改變,但是我們修改arr2[4].a時,arr中的相應元素跟著一起發生了改變。其實,我們對arr2數組中的元素直接進行改變(比如:arr2[0]=***,arr2[1]=***,arr2[3]=***)時,不會影響到原數組arr,但是我們修改數組中的[3,4,5]或{a:7}時,會造成原數組arr的改變。

結論:concat()方法對數組第一層進行了深拷貝。

可以再試試數組的slice()方法,它也是只對數組第一層進行了深拷貝。

2. Object.assign()和...展開運算符

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’}}var obj2 = {...obj1}obj2.a = 666obj2.c.name = ’xinxin’console.log(obj1) /* {a:1,b:[2,3,4],c:{name:’xinxin’}} */

可以看到利用...展開運算符實現的是對象第一層的深拷貝。后面的只是拷貝的引用值。

可以試試Object.assign()方法:

var obj1 = { a:1, b:[2,3,4], c:{name:’tanj’}}var obj2 = {}Object.assign(obj2,obj1)obj2.a = 666obj2.b[0] = 0console.log(obj1) /* {a:1,b:[0,3,4],c:{name:’tanj’} */

同樣,只對對象第一層進行了深拷貝,假如源對象的屬性值(例如obj1)是一個指向對象的引用,obj2也只拷貝那個引用值。所以改變obj2中b所指向的那個數組時,obj1的值也會發生改變。

我們可以自己實現一個這樣的效果,只對第一層進行深拷貝:

function shallowClone(source) { const newObj = source.constructor === Array ? [] : {} for (let keys in source) { if (source.hasOwnProperty(keys)) { newObj[keys] = source[keys]} } return newObj}

以上就是分析JavaScript中的深淺拷貝的詳細內容,更多關于JavaScript 深淺拷貝的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美特黄一级| 久久国产成人| 亚洲精品福利| 国产偷自视频区视频一区二区| 黑森林国产精品av| 美女视频网站久久| 欧美一级二区| 日本成人在线网站| 999在线观看精品免费不卡网站| 91精品久久久久久久久久不卡| 日韩欧美一区二区三区在线视频| 精品欠久久久中文字幕加勒比| 国产精品久久久久久久久久妞妞| 欧美欧美黄在线二区| 日本精品一区二区三区在线观看视频| 一区二区91| 日韩精品免费观看视频| 视频在线观看一区| 在线一区二区三区视频| 亚洲人成亚洲精品| 日韩精品高清不卡| 国产精品嫩草影院在线看| 国产福利一区二区精品秒拍| 国产日韩欧美一区在线| 奇米狠狠一区二区三区| 国产剧情在线观看一区| 国产精品一区二区三区av| 久久久国产精品网站| 国产一区二区三区视频在线| 国产欧美一区二区三区精品酒店| 日韩欧美一区免费| 91精品精品| 久久国产高清| 亚洲精品看片| 国产精品tv| 国产精品成久久久久| 视频福利一区| 久久国产高清| 日韩高清在线不卡| 麻豆91精品视频| 日韩精品麻豆| 免费观看在线综合色| 青草国产精品| 黄色aa久久| 亚洲综合不卡| 欧美一区网站| 午夜精品久久久久久久久久蜜桃| 日韩一区二区免费看| 日韩有吗在线观看| 久久久国产精品网站| 欧美性感美女一区二区| 亚洲另类黄色| 国产成人免费av一区二区午夜| 日韩精品一区二区三区免费观看| 免费成人网www| 一区二区三区网站| 欧美成人一二区| 精品中文字幕一区二区三区av| 日韩综合一区二区| 国产成人久久精品麻豆二区 | 欧美成人a交片免费看| 先锋影音国产一区| 精品中文字幕一区二区三区| 另类亚洲自拍| 欧美激情综合| 久久国产88| 天堂√8在线中文| 青青草国产成人99久久| 欧美一级精品| 免费视频一区二区三区在线观看 | 青青伊人久久| 最近高清中文在线字幕在线观看1| 亚洲一区二区毛片| 91精品丝袜国产高跟在线| 欧美成人基地 | 亚洲欧美日韩综合国产aⅴ| 免费成人性网站| 97在线精品| 亚洲激情欧美| 国产高清精品二区| 亚洲高清不卡| 日本va欧美va欧美va精品| 嫩草伊人久久精品少妇av杨幂| 日韩电影免费网址| 丝袜美腿高跟呻吟高潮一区| 国产精品va| 亚洲高清影视| 日韩av一区二区在线影视| 好吊一区二区三区| 里番精品3d一二三区| 午夜免费一区| 美女视频一区在线观看| 欧美在线亚洲| 久久不卡国产精品一区二区| 国产精品av久久久久久麻豆网| 欧美日韩视频免费看| 亚洲成人二区| 国产精品高潮呻吟久久久久| 久久精品国产99久久| 日韩中文av| 99精品综合| 久久麻豆视频| 石原莉奈在线亚洲三区| 国产suv精品一区| 亚洲丝袜美腿一区| 四虎4545www国产精品| 精品日韩一区| 欧美精品中文| 中文久久精品| 国产网站在线| 国产亚洲字幕| 亚洲一区成人| 999国产精品视频| 牛牛精品成人免费视频| 在线视频精品| 精品中文在线| 欧美黄色一区二区| 日韩中文字幕视频网| 欧美午夜不卡| 蜜臀久久精品| 国产精品亚洲欧美日韩一区在线| 在线亚洲免费| 激情欧美亚洲| 裤袜国产欧美精品一区| av免费不卡国产观看| 国产精品成人自拍| 亚洲影院天堂中文av色| 久久精品高清| 日韩在线综合| 国产精品mm| 日韩欧美2区| 免费日韩一区二区| 99精品视频在线| 日本在线视频一区二区| 日韩精选在线| 午夜久久av | 天堂成人国产精品一区| 欧美中文字幕一区二区| 美女视频网站久久| 欧美亚洲国产日韩| 亚洲精品影院在线观看| 天堂а√在线最新版中文在线| 美女性感视频久久| 国产精区一区二区| 国产美女亚洲精品7777| 日韩欧美美女在线观看| 在线精品国产亚洲| 国产亚洲福利| 在线午夜精品| 夜夜精品视频| 亚洲欧洲一区二区天堂久久| 欧美精品一卡| av亚洲免费| 日韩网站中文字幕| 在线天堂中文资源最新版| 久久免费影院| 久久三级中文| 国产一区福利| 蜜桃成人av| 六月丁香综合| 免费日韩av| 国产情侣一区| 精品一二三区| 私拍精品福利视频在线一区| 国产一区日韩一区| 亚洲aⅴ网站| 国产探花一区| 精品日韩在线| 国产精品久久久久毛片大屁完整版| 国产精品国产三级国产在线观看| 久久久免费人体| 黑人精品一区| 免费视频一区三区| 视频一区二区三区入口| 亚洲精品大片| 国产精品www994| 成人亚洲一区| 久久视频国产| 免费成人在线观看| 激情久久一区二区| 日韩激情av在线| 电影91久久久| 国产麻豆久久| 欧美日韩激情| 一区二区精品| 国产精品极品| 四虎成人av| 亚洲精品无播放器在线播放| 久久av电影| 三级小说欧洲区亚洲区| 亚洲欧洲日本mm| 日韩国产欧美三级| 日本一二区不卡| 五月天激情综合网| 精品日产乱码久久久久久仙踪林| 四虎4545www国产精品| 亚洲无线观看| 国产精品99视频| 日韩在线网址| 久久影视三级福利片|