深拷贝deepClone详解

在上一篇已经讲了深复制和浅复制的区别,就是引用复制和值复制的区别。见数组

  • 基本数据类型的特点:数据直接存储在栈(stack)内存中
  • 引用数据类型的特点:在栈中存储的是该对象引用,真实的数据存放在堆内存里

# 实现方式一:借助JSON方法,不能深拷贝函数

JSON.stringify():用于将 JavaScript 值转换为 JSON 字符串 JSON.parse():用于将一个 JSON 字符串转换为对象。

let arr1 = [{ value: 1}, { value: 2}, 'str'];
let arr2 = JSON.parse(JSON.stringify(arr1));
arr1[0].value = 3;
console.log(arr1) 
console.log(arr2) 

# 实现方式二:手写函数实现

要深拷贝实现值复制,就是不得不判断值的类型(getType见类型判断的几种方式),以进一步选择赋值方式。核心思想:递归遍历数组、对象做值复制

  • 非引用复制,直接赋值
  • 引用赋值,遍历递归赋值
const deepClone = (data) => {
  let type = getType(data);
  let tempValue;
  if(!(type === 'array' || type === 'object')) return data;
  if(type === 'array') {
    tempValue = [];
    data.forEach((item) => {
      tempValue.push(deepClone(item));
    })
    return tempValue;
  } else if(type === 'object') {
    tempValue = {};
    for(const key in data) {
      if (data.hasOwnProperty(key)) {
        tempValue[key] = deepClone(data[key]);
      }
    }
    return tempValue;
  }
}

虽然大概意思实现了,但是在生产环境建议使用underscore或lodash,他们考虑了更加完整的情况,比如function、Map、Set的处理等。

附加浅拷贝的实现方式

  • Object.assign
  • Array.prototype.concat
  • Array.prototype.slice

本文地址:

参考

相关文章推荐

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值