js的浅拷贝与深拷贝

  • 浅拷贝 :只复制一层,对象里的子对象仍是引用

  • 深拷贝:所有层级的属性都会被完整复制,互不影响。

浅拷贝

常见方法:

js 复制代码
const newObj = { ...oldObj };           // ES6 展开运算符
const newObj = Object.assign({}, oldObj); // assign 方式
const newArr = oldArr.slice();          // 数组浅拷贝
const newArr = [...oldArr];             // 数组展开运算符
js 复制代码
const obj1 = {
  name: 'Alice',
  info: {
    age: 25
  }
};

const obj2 = { ...obj1 }; // 浅拷贝

obj2.name = 'Bob'; // ✅ 只影响 obj2

obj2.info.age = 30; // ❗️同时改变 obj1.info.age

console.log(obj1.info.age); // 30

深拷贝

深拷贝会递归地复制对象的所有层级,两个对象完全独立。

方法1 :JSON.parse(JSON.stringify(obj))

js 复制代码
const obj2 = JSON.parse(JSON.stringify(obj1));

不能拷贝函数、undefined、循环引用、Symbol、BigInt、日期、Map、Set 等复杂结构。

方法二:自己写递归函数(复杂)

js 复制代码
function deepClone(obj) {
  if (obj === null || typeof obj !== 'object') return obj;

  if (Array.isArray(obj)) {
    return obj.map(item => deepClone(item));
  }

  const clone = {};
  for (let key in obj) {
    if (obj.hasOwnProperty(key)) {
      clone[key] = deepClone(obj[key]);
    }
  }
  return clone;
}

方法三:使用库

使用现成的库,如:

  • lodash: _.cloneDeep(obj)
  • rfdc(更轻量)
bash 复制代码
npm install lodash
js 复制代码
import _ from 'lodash';

const newObj = _.cloneDeep(oldObj);
相关推荐
吴声子夜歌2 小时前
TypeScript——模块解析
javascript·ubuntu·typescript
han_2 小时前
JavaScript设计模式(五):装饰者模式实现与应用
前端·javascript·设计模式
ProgramHelpOa3 小时前
Amazon SDE Intern OA 2026 最新复盘|70分钟两题 Medium-Hard
java·前端·javascript
smchaopiao3 小时前
如何用CSS和JS搞定全屏图片展示
前端·javascript·css
还是大剑师兰特3 小时前
将 Utils.js 挂载为全局(window.Utils.xx)完整配置方案
开发语言·javascript·ecmascript
前端Hardy4 小时前
Qwik 2.0 Beta 来了:不靠 AI,只靠 Resumability,首屏交互快到离谱
前端·javascript·面试
前端Hardy4 小时前
NW.js v0.109.1 最新稳定版发布:被遗忘的桌面开发神器?启动快 3 倍,内存省 70%!
前端·javascript·vue.js
Jinuss4 小时前
源码分析之React中副作用Effect全流程
前端·javascript·react.js
大家的林语冰5 小时前
《前端周刊》尤大官宣 Vite 8 稳定版首发!npm 新官网?React 官网更新。focusgroup 新功能!
前端·javascript·vite
kuuailetianzi5 小时前
构建企业级督办任务系统:Vue3 + TypeScript 实战(多级任务拆解+批量操作+进度追踪+单元格合并)
前端·javascript·typescript