js 浅与深拷贝

Posted 恒之心

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 浅与深拷贝相关的知识,希望对你有一定的参考价值。

 1、浅拷贝

let obj1 = {
  a: 1,
  b: 2
}
let obj2 = obj1
obj2.b = 3
console.log(obj1)  // { a: 1, b: 3 }
console.log(obj1 === obj2) //true

 

 2、深拷贝

function deepCopy(obj) {
   if(typeof obj === "object") {
       if(obj.constructor === Array) {
           var newArr = []
           for(var i = 0; i < obj.length; i++) newArr.push(obj[i])
           return newArr
       } else {
           var newObj = {}
           for(var key in obj) {
               newObj[key] = this.deepCopy(obj[key])
           }
           return newObj
       }
   } else {
       return obj
   }
}//理解版

 

let obj1 = {
  a: ‘1‘,
  b: ‘2‘,
  c: {
    d: ‘3‘
  },
  d: function aa () {}
}
function deepCopy (obj) { //简化后
  let temp = obj.constructor === Array ? [] : {}
  for (let val in obj) {
    temp[val] = typeof obj[val] == ‘object‘ ? deepCopy(obj[val]) : obj[val]
  }
  return temp
}
console.log(deepCopy(obj1)) //{ a: ‘1‘, b: ‘2‘, c: { d: ‘3‘ }, d: [Function: aa] }

 

以上是关于js 浅与深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

Javascript/js 的浅拷贝与深拷贝(复制)学习随笔

JS的浅拷贝与深拷贝

js对象的浅拷贝与深拷贝

小tips:JS之浅拷贝与深拷贝

js的浅拷贝与深拷贝

浅拷贝与深拷贝