js的浅拷贝和深拷贝和运用场景

为何会用到浅拷贝和深拷贝

起首来看一下以下代码

let a = b = 2
a = 3
console.log(a)
console.log(b)
let c = d = [1,2,3]
let e = f = {a:1,b:2,c:3}
c[0] = 2
e.a = 2
console.log(d[0])
console.log(f.a)

你会发明,同一个Array或许Object赋值给两个差别变量时,变量指向的是同一个内存地址,所以就会形成个中一个变量转变属性值,同时转变了别的一个变量的对应属性值。

而大多数现实项目中,我们想要的结果是两个变量(初始值雷同)互不影响。所以就要运用到
拷贝(分为深浅两种)

深浅拷贝的区分

浅拷贝只复制一层对象的属性,而深拷贝则递归复制了一切层级。

浅拷贝有效性针对的是单一层级对象
[1,2,3]或许{a:1,b:2}

深拷贝有效性针对的是单层或许多层级对象
[1,2,3]或许{a:1,b:2}或许[1,[1],{a:1}]或许{a:[1],b:{c:2}}

浅拷贝

  • 怎样完成
// 数组
let a = [1,2]
let b = a.slice()
// {}
let e = {a:[1],b:{d:1},2}
let f = Object.create(e)
function shallowCopy (obj) {
    if (typeof obj === 'object' && obj !== null) {
        if (Array.isArray(obj)) {
            return obj.slice()
        } else {
            let result = {}
            Object.keys(obj).forEach((item,i) = > {
                console.log(i)
                result[item] = obj[item]
            })
            return result
        }
    } else {
        return obj
    }
}
  • 运用场景
    关于一层构造的Array和Object想要拷贝一个副本时运用
    vue的mixin是浅拷贝的一种庞杂型式

深拷贝

  • 怎样完成
// 应用JSON(它能正确处理的对象是Number, String, Boolean, Array, 扁平对象)
let g = JSON.parse(JSON.stringify(obj))
// 适用于
function deepCopy (obj) {
  if (typeof obj === 'object' && obj !== null) {
    let objKeys = Object.keys(obj)
    let result
    if (Array.isArray(obj)) {
      result = []
    } else {
      if (obj.constructor === Object) {
        result = {}
      } else {
        return obj
      }
    }
    objKeys.forEach((item) => {
      if (typeof obj[item] === 'object' && obj[item] !== null) {
        switch (obj[item].constructor) {
          case Array:
            result[item] = deepCopy(obj[item])
            break
          case Object:
            result[item] = deepCopy(obj[item])
            break
          case Date:
            result[item] = new Date(obj[item])
            break
          case RegExp:
            let attributes = ''
            attributes += obj[item].global ? 'g' : ''
            attributes += obj[item].ignoreCase ? 'g' : ''
            attributes += obj[item].multiline ? 'g' : ''
            result[item] =  new RegExp(obj[item].source, attributes);
            break
          default:
            result[item] = obj[item]
            break
        }
      } else {
        result[item] = obj[item]
      }
    })
    return result
  } else {
    return obj
  }
}
  • 运用场景
    复制深层次的object数据构造
  • 对深拷贝的运用主意
    在现实工作中是否是用继续来完成更好?须要人人来议论,提意见
    原文作者:孙小渃
    原文地址: https://segmentfault.com/a/1190000013655660
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞