js深拷贝三种方法

使用递归函数实现深拷贝

javascript 复制代码
const obj = {
      name: 'zzz',
      age: 18,
      hobby: ['篮球', '足球'],
      family: {
        baby: 'baby'
      }
    }
// 深拷贝   数组  对象  一定要先筛数组再筛对象,因为万物皆对象
    function deepcopy(newObj, oldObj) {
      for (const k in oldObj) {
        // 判断值是否属于array类
        if (oldObj[k] instanceof Array) {
          // 先将newo中hobby置空  newObj[hobby]=[]
          newObj[k] = []
          // 然后再将旧数据的数组值拷贝给新的数组值  newObj[hobby]=oldObj[hobby]
          deepcopy(newObj[k], oldObj[k])
        } else if (oldObj[k] instanceof Object) {
          newObj[k] = {}
          deepcopy(newObj[k], oldObj[k])
        } else {
          //newObj[k] ===newObj.name  给对象添加新属性
          newObj[k] = oldObj[k]
        }
      }
    }
 const newo = {}
    deepcopy(newo, obj)
    console.log(newo);
    newo.age = 11
    newo.hobby[0] = '羽毛球'
    newo.family.baby = 'bbbb'
    console.log(obj);

使用lodash的_.cloneDeep方法实现深拷贝

官网下载lodash https://www.lodashjs.com/

javascript 复制代码
//引用
  <script src="./lodash.min.js"></script>
 // lodash库
    const obj_l = {
      name: 'zzz',
      age: 18,
      hobby: ['篮球', '足球'],
      family: {
        baby: 'baby'
      }
    }
    const o_l = _.cloneDeep(obj_l)

    o_l.age = 11
    o_l.hobby[0] = '羽毛球'
    o_l.family.baby = 'bbbb'
    console.log(o_l);
    console.log(obj_l);

使用json的JSON.parse()JSON.stringify()方法实现深拷贝

javascript 复制代码
    // json深拷贝
    const obj_j = {
      name: 'zzz',
      age: 18,
      hobby: ['篮球', '足球'],
      family: {
        baby: 'baby'
      }
    }
    // /JSON.stringify  将对象转为json字符串
    const o_j = JSON.parse(JSON.stringify(obj_j))
    o_j.age = 11
    o_j.hobby[0] = '羽毛球'
    o_j.family.baby = 'bbbb'
    console.log(o_j);
    console.log(obj_j);
相关推荐
不会敲代码110 小时前
手写 Zustand:三十分钟带你搞懂状态管理库的核心原理
前端·javascript·源码
神奇的程序员11 小时前
重构了自己5年前写的截图插件
前端·javascript·架构
橙淮11 小时前
从优化到安全再到未来 ——JavaScript 全维度技术指南
javascript
UXbot12 小时前
一人独立交付 UI + 前端:AI 驱动 UI 设计工具的五大功能模块深度评测
前端·低代码·ui·设计模式·交互
kobesdu12 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
诚实可靠王大锤12 小时前
React Native 输入框与按钮焦点冲突解决方案(rn版本0.70.3)
前端·javascript·react native·react.js
kyriewen13 小时前
测试妹子让我写单测,我偷偷用AI一天干完一周的活
前端·chatgpt·cursor
2601_9577808413 小时前
Claude Code 2026年最新部署指南:从环境搭建到技能扩展
前端·人工智能·ai编程·claude
zhangfeng113313 小时前
workbuddy 专家 “前端开发师” 结合nvidia-mistral-small-4-119b-2603 项目计划-前端界面开发.md
前端·人工智能·免费
IT_陈寒15 小时前
为什么Java的Stream并行处理反而变慢了?
前端·人工智能·后端