前端刷题-深浅拷贝

深拷贝

javascript 复制代码
function deepClone(obj) {
  if (obj === null || typeof obj !== "object") {
    return obj;
  }

  if (obj instanceof Date) {
    return new Date(obj);
  }

  if (obj instanceof Array) {
    const cloneArray = [];
    for (let i = 0; i < obj.length; i++) {
      cloneArray[i] = deepClone(obj[i]);
    }
    return cloneArray;
  }

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

在实际开发中通常不会这么使用深拷贝,ES6 中的 JSON.parse(JSON.stringify(obj))也可以用于深拷贝,但有一定的限制比如不能用于复制函数和循环引用

javascript 复制代码
function deepClone2(obj) {
  const cloneObj = JSON.parse(JSON.stringify(obj));
  return cloneObj;
}

验证

javascript 复制代码
const originalObject = {
  name: "John",
  age: 30,
  address: {
    city: "New York",
    country: "USA",
  },
  hobbies: ["reading", "traveling"],
};

const copiedObject = deepClone(originalObject);
console.log(copiedObject);

浅拷贝

javascript 复制代码
function shallowClone(obj) {
  if (obj === null || typeof obj !== "object") {
    return obj;
  }

  if (obj instanceof Array) {
    const cloneArray = [];
    for (let i = 0; i < obj.length; i++) {
      cloneArray[i] = obj[i];
    }
    return cloneArray;
  }

  if (obj instanceof Object) {
    const cloneObject = {};
    for (let key in obj) {
      if (obj.hasOwnProperty(key)) {
        cloneObject[key] = obj[key];
      }
    }
    return cloneObject;
  }
}

浅拷贝与深拷贝的区别在于,深拷贝是层级式的将原数据完全拷贝成为一份新的数据,浅拷贝仅仅是对数据的第一层进行拷贝。当改变拷贝数据的深层数据时,浅拷贝会影响原数据而深拷贝不会影响原数据。

验证

javascript 复制代码
const originalObject = {
  name: "John",
  age: 30,
  hobbies: ["reading", "traveling"],
};

const copiedObject = shallowClone(originalObject);
console.log(copiedObject);

copiedObject.name = "Alice";
copiedObject.hobbies.push("swimming");

console.log(originalObject);
相关推荐
葡萄城技术团队35 分钟前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰1 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans1 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端
徐小夕1 小时前
JitWord 2.3: 墨定,行远
前端·vue.js·github
南果梨1 小时前
OpenClaw 完整教程!从安装到使用(官方脚本版)
前端·git·开源
大雨还洅下1 小时前
前端手写: new操作符
前端
hqk1 小时前
鸿蒙项目实战:手把手带你实现 WanAndroid 布局与交互
android·前端·harmonyos
是糖糖啊2 小时前
OpenClaw 从零到一实战指南(飞书接入)
前端·人工智能·后端
Despupilles2 小时前
第三篇、基本骨架结构
前端
swipe2 小时前
从原理到手写:彻底吃透 call / apply / bind 与 arguments 的底层逻辑
前端·javascript·面试