欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

帶你搞懂js的深拷貝

 更新時(shí)間:2021年11月15日 16:01:01   作者:浪漫主義碼農(nóng)  
這篇文章主要為大家介紹了js的深拷貝,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

js深拷貝

在講正題之前我們要先了解數(shù)據(jù)存儲(chǔ)的方式

數(shù)據(jù)存儲(chǔ)方式

在講之前我們要先知道值類型和引用類型的存儲(chǔ)方式。

在JavaScript數(shù)據(jù)類型中有兩種數(shù)據(jù)類型。

值類型:字符串(String)、數(shù)字 (Number)、布爾 (Boolean)、空(Null)、未定義(Undefined)、Symbol。

存放在棧內(nèi)存中的簡(jiǎn)單數(shù)據(jù)段,數(shù)據(jù)大小確定,內(nèi)存空間大小可以分配。

引用數(shù)據(jù)類型:對(duì)象 (Object) 、數(shù)組 (Array) 、函數(shù) (Function) 。

存放在堆內(nèi)存中的對(duì)象,在棧內(nèi)存中存的是一個(gè)指針,這個(gè)指針指向堆內(nèi)存一個(gè)位置。再從堆內(nèi)存中取得所需的數(shù)據(jù)。

存儲(chǔ)如下圖:

在這里插入圖片描述

什么是淺/深拷貝

講完存儲(chǔ)的方式,我們來講講淺拷貝和深拷貝

拷貝也就是我們常常講的copy,ctrl+c,ctrl+v,那么我們來看看例子

當(dāng)我們對(duì)分別值類型和引用類型進(jìn)行賦值。

     var a = 5
     var b = a
     b += 5
     console.log('a=' + a,'b=' + b)
     var arr=[1,2,3]
     var brr=arr
     brr.push(10)
     console.log("arr為",arr)
     console.log("brr為",brr)

在這里插入圖片描述

現(xiàn)象:我們發(fā)現(xiàn)值類型并沒有互相受到影響,然而數(shù)組(引用類型)brr數(shù)組添加元素的時(shí)候改變了arr數(shù)組。

解釋分析:淺拷貝只會(huì)發(fā)生在引用類型身上,對(duì)于引用類型如果之進(jìn)行簡(jiǎn)單的賦值,只會(huì)賦值指向堆內(nèi)存的指針,這種稱為淺拷貝。而深拷貝就是完全拷貝一個(gè)引用類型,為不是地址指針。

淺拷貝看下面這張?jiān)韴D:

在這里插入圖片描述

常用深拷貝實(shí)現(xiàn)

那么我們?cè)谫x值引用類型的時(shí)候肯定不能出現(xiàn)淺拷貝的現(xiàn)象,對(duì)原數(shù)據(jù)產(chǎn)生影響了。那么就要進(jìn)行深拷貝

1.通過JSON.stringify和JSON.parse

可以深拷貝的數(shù)組和對(duì)象,但是不能拷貝函數(shù),可以進(jìn)行對(duì)象或者數(shù)組的嵌套拷貝。

缺點(diǎn):無法實(shí)現(xiàn)對(duì)對(duì)象中方法的深拷貝

使用

     var brr=JSON.parse(JSON.stringify(arr))

例子:

  var arr = {
         name: '浪漫主義碼農(nóng)',
         age: 20,
         adress: ['jiangxi', 'changsha'],
         friends: {
             friend1: '張三',
             friend2: '李四'
         },
         function(){
             console.log("我是浪漫主義的對(duì)象")
         }
     }
     var brr=JSON.parse(JSON.stringify(arr))
     brr.name='法外狂徒張三'
     brr.adress[0]='長沙'
     console.log("arr為", arr)
     console.log("brr為", brr)

在這里插入圖片描述

2.擴(kuò)展運(yùn)算符

利用了對(duì)象的結(jié)構(gòu)賦值特性方法。

缺點(diǎn):無對(duì)對(duì)象里面嵌套的對(duì)象進(jìn)行深拷貝,相當(dāng)于只是對(duì)一層引用對(duì)象進(jìn)行深拷貝

使用:

     var brr={...arr}

例子:

  var arr = {
         name: '浪漫主義碼農(nóng)',
         age: 20,
         adress: ['jiangxi', 'changsha'],
         friends: {
             friend1: '張三',
             friend2: '李四'
         },
         function(){
             console.log("我是浪漫主義的對(duì)象")
         }
     }
     var brr={...arr}
     brr.name='法外狂徒張三'
     brr.adress[0]='長沙'
     console.log("arr為", arr)
     console.log("brr為", brr)

在這里插入圖片描述

3.手寫遞歸深拷貝函數(shù)

完美解決

函數(shù):

  //使用遞歸實(shí)現(xiàn)深拷貝
     function deepClone(obj) {
         //判斷拷貝的obj是對(duì)象還是數(shù)組
         var objClone = Array.isArray(obj) ? [] : {};
         if (obj && typeof obj === "object") { //obj不能為空,并且是對(duì)象或者是數(shù)組 因?yàn)閚ull也是object
             for (key in obj) {
                 if (obj.hasOwnProperty(key)) {
                     if (obj[key] && typeof obj[key] === "object") { //obj里面屬性值不為空并且還是對(duì)象,進(jìn)行深度拷貝
                         objClone[key] = deepClone(obj[key]); //遞歸進(jìn)行深度的拷貝
                     } else {
                         objClone[key] = obj[key]; //直接拷貝
                     }
                 }
             }
         }
         return objClone;
     }

例子:

      var arr = {
         name: '浪漫主義碼農(nóng)',
         age: 20,
         adress: ['jiangxi', 'changsha'],
         friends: {
             friend1: '張三',
             friend2: '李四'
         },
         fun: function(){
             console.log("我是" + this.name + "的對(duì)象")
         }
     }
     var brr = deepClone(arr)
     brr.name = '法外狂徒張三'
     brr.adress[0] = '長沙'
     console.log("arr為", arr)
     arr.fun()
     console.log("brr為", brr)
     brr.fun()
 ​
     //使用遞歸實(shí)現(xiàn)深拷貝
     function deepClone(obj) {
         //判斷拷貝的obj是對(duì)象還是數(shù)組
         var objClone = Array.isArray(obj) ? [] : {};
         if (obj && typeof obj === "object") { //obj不能為空,并且是對(duì)象或者是數(shù)組 因?yàn)閚ull也是object
             for (key in obj) {
                 if (obj.hasOwnProperty(key)) {
                     if (obj[key] && typeof obj[key] === "object") { //obj里面屬性值不為空并且還是對(duì)象,進(jìn)行深度拷貝
                         objClone[key] = deepClone(obj[key]); //遞歸進(jìn)行深度的拷貝
                     } else {
                         objClone[key] = obj[key]; //直接拷貝
                     }
                 }
             }
         }
         return objClone;
     }

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • javascript+css實(shí)現(xiàn)俄羅斯方塊小游戲

    javascript+css實(shí)現(xiàn)俄羅斯方塊小游戲

    這篇文章主要為大家詳細(xì)介紹了javascript+css實(shí)現(xiàn)俄羅斯方塊小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 微信小程序3D輪播實(shí)現(xiàn)代碼

    微信小程序3D輪播實(shí)現(xiàn)代碼

    這篇文章主要介紹了微信小程序3D輪播實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • JavaScript 格式字符串的應(yīng)用

    JavaScript 格式字符串的應(yīng)用

    在使用JavaScript中的Date對(duì)象時(shí),有一個(gè)常用的操作就是輸出。但Date對(duì)象自帶的toString()方法輸出的格式并不能滿足用戶多樣化的需求。我在想,是不是可以將C#中DateTime.ToString(string format)方法的形式引入到JavaScript中呢?
    2010-03-03
  • JavaScript基于ChatGPT?API實(shí)現(xiàn)劃詞翻譯瀏覽器腳本

    JavaScript基于ChatGPT?API實(shí)現(xiàn)劃詞翻譯瀏覽器腳本

    最近?GitHub?上有個(gè)基于?ChatGPT?API?的瀏覽器腳本,openai-translator,?短時(shí)間內(nèi)?star?沖到了?9.7k,拋開?tauri?是使用?rust?部分,那瀏覽器部分實(shí)現(xiàn)還是比較簡(jiǎn)單的,今天我們就來手動(dòng)實(shí)現(xiàn)一下
    2023-03-03
  • 淺談JavaScript的自動(dòng)垃圾收集機(jī)制

    淺談JavaScript的自動(dòng)垃圾收集機(jī)制

    本文主要對(duì)JavaScript的自動(dòng)垃圾收集機(jī)制進(jìn)行簡(jiǎn)要分析,并介紹了垃圾收集的方式:標(biāo)記清除(mark-and-sweep)和引用計(jì)數(shù)(reference counting),需要的朋友一起來看下吧
    2016-12-12
  • 微信公眾號(hào)生成新浪短網(wǎng)址的實(shí)現(xiàn)(快速生成)

    微信公眾號(hào)生成新浪短網(wǎng)址的實(shí)現(xiàn)(快速生成)

    這篇文章主要介紹了微信公眾號(hào)生成新浪短網(wǎng)址的實(shí)現(xiàn)(快速生成),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • ES6 let和const定義變量與常量的應(yīng)用實(shí)例分析

    ES6 let和const定義變量與常量的應(yīng)用實(shí)例分析

    這篇文章主要介紹了ES6 let和const定義變量與常量的應(yīng)用,結(jié)合實(shí)例形式分析了ES6使用let定義變量以及使用const定義常量的相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • js 圖片隨機(jī)不定向浮動(dòng)的實(shí)現(xiàn)代碼

    js 圖片隨機(jī)不定向浮動(dòng)的實(shí)現(xiàn)代碼

    這篇文章介紹了js圖片隨機(jī)不定向浮動(dòng)的實(shí)現(xiàn)代碼,有需要的朋友可以參考一下
    2013-07-07
  • javascript的alert box在java中如何顯示多行

    javascript的alert box在java中如何顯示多行

    這篇文章主要介紹了javascript的alert box在java中如何顯示多行,需要的朋友可以參考下
    2014-05-05
  • 詳解ECMAScript2019/ES10新屬性

    詳解ECMAScript2019/ES10新屬性

    這篇文章主要介紹了詳解ECMAScript2019/ES10新屬性,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12

最新評(píng)論