深拷贝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
    评论
拷贝是指完全复制一个对象,包括它的引用类型数据(如数组、对象等),而不是只复制它们的地址或引用。拷贝的目的是为了保持原始对象和新对象的独立性,避免它们之间相互影响。 实现拷贝的方法有很多,比较常用的有递归、JSON序列化和反序列化、lodash库等。下面分别介绍这些方法的实现方式。 1. 递归 使用递归的方式可以遍历对象的每一个属性,并将其复制到新的对象中。同时,如果属性的值仍然是一个对象,就递归地调用拷贝函数,直到遍历完所有的属性。 ```javascript function deepClone(obj) { if (typeof obj !== 'object' || obj === null) { return obj; } const newObj = Array.isArray(obj) ? [] : {}; for (const key in obj) { if (Object.hasOwnProperty.call(obj, key)) { newObj[key] = deepClone(obj[key]); } } return newObj; } ``` 2. JSON序列化和反序列化 使用JSON.stringify()方法将原始对象序列化为一个JSON字符串,然后使用JSON.parse()方法将JSON字符串反序列化为一个新的对象。 ```javascript function deepClone(obj) { return JSON.parse(JSON.stringify(obj)); } ``` 这种方法的缺点是,如果原始对象中有函数、正则表达式、Date等对象时,在序列化和反序列化过程中会丢失它们的类型,变成了字符串或空对象。 3. lodash库 lodash是一个常用的JavaScript工具库,提供了许多方便的函数,包括拷贝函数。 ```javascript const _ = require('lodash'); const obj = {a: 1, b: {c: 2, d: {e: 3}}}; const newObj = _.cloneDeep(obj); ``` 使用lodash库的拷贝函数可以处理原始对象中的函数、正则表达式、Date等对象,保持它们的类型不变。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值