国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

javascript - js里面的clone方法有什么用?

瀏覽:99日期:2023-06-09 14:09:12

問題描述

有時候對數組之類的操作的時候,會使用clone方法,感覺不使用這個直接賦值也可以啊,這樣做有什么好處?為了省內存?還有什么淺拷貝深拷貝之類的,原諒我是小白。。

問題解答

回答1:

好處就是,不同于“=”,clone的數組是在內存中是獨立的,你可以對它為所欲為。

js中,數組和對象都屬于引用類型。

const arr = [1, 2, 3, 4, 5, 6];const arr1 = arr; // 直接賦值,arr1指向的是arr的內存,也就是說arr發生改變時,arr1也會被改變arr.push(123);console.log(arr1); // [1, 2, 3, 4, 5, 6, 123]

const arr = [1, 2, 3, 4, 5, 6];const arr1 = arr.slice(0); // 克隆了一個arr1,arr與arr1指向不同的內存,arr的改變并不會影響到arr1arr.push(123);console.log(arr1); // [1, 2, 3, 4, 5, 6]

所以,克隆的作用就是用來新生成一份數據,不污染原來的數據。

至于深拷貝與淺拷貝:

const obj1 = { name: ’Ash’, class: {a: 1,b: 2, }};// 淺拷貝const obj2 = {};for (let key in obj1) { obj2[key] = obj1[key];}// 深拷貝const copyObj = (obj) => { const newObj = {}; for (let key in obj) {if (typeof obj[key] !== ’object’) { newObj[key] = obj[key];} else { newObj[key] = copyObj(obj[key]);} } return newObj;}const obj3 = copyObj(obj1);obj1.name = ’Coco’;obj1.class.a = 100;console.log(obj2.name, obj2.class.a); // Ash 100console.log(obj3.name, obj3.class.a); // Ash 1

可以看到,淺拷貝與深拷貝的區別在于:淺拷貝只是遍歷了obj1的第一層,然后把obj1的每個屬性都賦值給了obj2;而深拷貝則不會,當屬性值為對象時,深拷貝會new一個空對象,然后把對象的值賦值給這個空對象,在返回這個空對象作為obj3的屬性。

回答2:

JS 編程中很重要的一個原則是「不是你的對象不要動」

做個形象的比喻,我借給你一本書(object),我以為你只是要閱讀(read),你卻拿去練字(write),這本書還給我我都沒辦法在讀到正常的內容了。

而 deepClone 就解決了這個問題,我給你一本書,你去復印一下,書原樣還給我,復印本你就可以隨意處置了。

回答3:

javascript中的深拷貝和淺拷貝?

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 玖玖精品国产 | 女让张开腿让男人桶视频 | 日本巨乳中文字幕 | 永久免费毛片在线播放 | freex性日韩 free性chinese国语对白 | 在线永久免费观看黄网站 | 日韩欧美一区二区中文字幕 | 成人免费观看永久24小时 | 国产精品二区页在线播放 | aa大片成人免费网站 | 久久午夜影院 | 久久看视频 | 99久99久6久热在线播放 | 黄色三级理沦片 | 日韩日韩日韩手机看片自拍 | 免费一级特黄特色黄大任片 | 天海翼精品久久中文字幕 | 亚洲男人的天堂在线观看 | 亚洲一区在线观看视频 | 国内自拍一区 | 亚洲福利视频一区二区三区 | 久久亚洲欧美成人精品 | 成人伊人青草久久综合网 | 久久精品一区二区免费看 | 欧美色另类 | 亚洲一区在线视频 | 杨幂国产精品福利在线观看 | 日本免费一级视频 | 波多野结衣视频在线观看地址免费 | 亚洲精品一区二区三区福利 | 国产成人综合欧美精品久久 | 久久久久久久99久久久毒国产 | 亚洲精品国精品久久99热 | 成人女人a毛片在线看 | 欧美日韩一区二区三区在线观看 | 国产欧美精品午夜在线播放 | 99国产精品一区二区 | 亚洲精品综合久久中文字幕 | 在线观看免费精品国产 | 在线不卡一区二区三区日韩 | 亚洲精品一区亚洲精品 |