操作數(shù)組以后,原數(shù)組發(fā)生改變;淺拷貝和深拷貝的區(qū)別

最近遇到一個問題是,給一個數(shù)組做了排序,會改變原數(shù)組的數(shù)值

此問題有兩種解決方式:

方法一:切斷數(shù)據(jù)之間的聯(lián)系

let?_arr?=?JSON.parse(JSON.stringify(_this.statisticsData.useData.useClickNum));?//為了防止改變——Arr從而改變useClickNum,轉變一下,切換數(shù)據(jù)聯(lián)系


方法二:深拷貝

根據(jù)詢問是因為淺拷貝的問題,如下提供淺拷貝和深拷貝的區(qū)別




深拷貝代碼附上:

functiondeepClone(o){

? ? // 判斷如果不是引用類型,直接返回數(shù)據(jù)即可? ? if (typeof o === 'string' || typeof o === 'number' || typeof o === 'boolean' || typeof o === 'undefined') {

? ? ? ? return o

? ? } else if (Array.isArray(o)) { // 如果是數(shù)組,則定義一個新數(shù)組,完成復制后返回? ? ? ? // 注意,這里判斷數(shù)組不能用typeof,因為typeof Array 返回的是object? ? ? ? console.log(typeof [])? // --> object? ? ? ? var _arr = []

? ? ? ? o.forEach(item=> { _arr.push(item) })

? ? ? ? return _arr

? ? } else if (typeof o === 'object') {

? ? ? ? var _o = {}

? ? ? ? for (let key in o) {

? ? ? ? ? ? _o[key] = deepClone(o[key])

? ? ? ? }

? ? ? ? return _o

? ? }

}var arr = [1, 2, 3, 5]var cloneArr = deepClone(arr)console.log(cloneArr)? // --> [ 1, 2, 3, 5 ]console.log(arr === cloneArr)? // --> falsevar obj = { name: 'ccc', age: 18 }var cloneObj = deepClone(obj)console.log(cloneObj)? // --> { name: 'ccc', age: 18 }console.log(obj === cloneObj)? // falseobj.name = 'www'console.log(obj)? ? // --> { name: 'www', age: 18 }console.log(cloneObj)? // --> { name: 'ccc', age: 18 }




文章轉載自:https://www.cnblogs.com/cirry/p/13395291.html

http://www.cnblogs.com/cirry/

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 1、淺拷貝## 拷貝就是把父對象的屬性,全部拷貝給子對象。接下來,我們看一個拷貝的例子: function ext...
    fullbook閱讀 613評論 0 3
  • JS數(shù)據(jù)類型思維導圖: 深拷貝與淺拷貝是針對引用數(shù)據(jù)類型而言,可分下面幾種: 一 JSON.parse(JSON....
    TerryMin00閱讀 423評論 0 0
  • 一、 基本數(shù)據(jù)類型的拷貝(復制copy)深拷貝和淺拷貝 深拷貝和淺拷貝是針對復雜數(shù)據(jù)類型來說的,淺拷貝只拷貝一層,...
    虛無縹緲_閱讀 354評論 0 0
  • 關于JavaScript的淺拷貝和深拷貝 在JS中有一些基本類型像是Number、String、Boolean,而...
    成都reactnative閱讀 350評論 0 0
  • 漸變的面目拼圖要我怎么拼? 我是疲乏了還是投降了? 不是不允許自己墜落, 我沒有滴水不進的保護膜。 就是害怕變得面...
    悶熱當乘涼閱讀 4,493評論 0 13

友情鏈接更多精彩內(nèi)容