数组和对象的深拷贝和浅拷贝的方法

数组和对象的深拷贝、浅拷贝方法有所不同,以下是常见的实现方式:

一、浅拷贝方法(数组和对象通用/专用)

浅拷贝只复制表层数据,嵌套的引用类型仍共享内存。

  1. 数组的浅拷贝
  • 扩展运算符(...): const arrCopy = [...originalArr];

  • Array.prototype.slice(): const arrCopy = originalArr.slice();

  • Array.prototype.concat(): const arrCopy = [].concat(originalArr);

  1. 对象的浅拷贝
  • 扩展运算符(...): const objCopy = {...originalObj};

  • Object.assign(): const objCopy = Object.assign({}, originalObj);

二、深拷贝方法(数组和对象通用/专用)

深拷贝会复制所有嵌套数据,原数据和拷贝数据完全独立。

  1. 通用方法(数组和对象均可)
  • JSON.parse(JSON.stringify()):

简单易用,但有局限性(不支持函数、Symbol、循环引用等)。

示例: const deepCopy = JSON.parse(JSON.stringify(original));

  • 递归实现:

自定义函数遍历所有属性,对引用类型递归拷贝,可处理复杂场景。

示例:

function deepClone(obj) {

if (obj === null || typeof obj !== 'object') return obj;

let copy = Array.isArray(obj) ? [] : {};

for (let key in obj) {

if (obj.hasOwnProperty(key)) {

copy[key] = deepClone(obj[key]);

}

}

return copy;

}

  1. 其他工具方法
  • Lodash库的_.cloneDeep():

成熟可靠,支持各种数据类型(推荐实际开发使用)。

示例: const deepCopy = _.cloneDeep(original);

总结

  • 浅拷贝适合无嵌套的简单数据,实现简单(扩展运算符、slice等)。

  • 深拷贝适合有嵌套引用类型的数据,复杂场景推荐用 Lodash 的 _.cloneDeep ,简单场景可临时用 JSON.parse(JSON.stringify()) (注意其局限性)。

相关推荐
这是个栗子4 小时前
【问题解决】npm包下载速度慢
前端·npm·node.js
weixin_584121434 小时前
vue3+ts+elementui-表格根据相同值合并
前端·javascript·elementui
吃手机用谁付的款5 小时前
HTML常见标签
前端·html
好好研究5 小时前
CSS样式中的布局、字体、响应式布局
前端·css
拉不动的猪7 小时前
前端小白之 CSS弹性布局基础使用规范案例讲解
前端·javascript·css
伍哥的传说7 小时前
React强大且灵活hooks库——ahooks入门实践之开发调试类hook(dev)详解
前端·javascript·react.js·ecmascript·hooks·react-hooks·ahooks
界面开发小八哥7 小时前
界面控件Kendo UI for Angular 2025 Q2新版亮点 - 增强跨设备的无缝体验
前端·ui·界面控件·kendo ui·angular.js
枷锁—sha8 小时前
从零掌握XML与DTD实体:原理、XXE漏洞攻防
xml·前端·网络·chrome·web安全·网络安全
F2E_Zhangmo8 小时前
基于cornerstone3D的dicom影像浏览器 第二章,初始化页面结构
前端·javascript·vue·cornerstone3d·cornerstonejs