用递归写一个深拷贝

上次面试的时候叫我手写一个递归完成深拷贝,当时不会,现在复习一下。

  let obj = {
      id: 1,
      name: 'zs',
      msg: {
        age: 18
      },
      color: ['blue', 'red', 'green']
    }
    let o = {}
    const deepCopy = (newobj, oldobj) => {
      for (let k in oldobj) {
        let item = oldobj[k]

        // 1.如果item是数组
        if (item instanceof Array) {
          newobj[k] = []
          // 重复
          // for(let j in item){
          //   newobj[k][j]=item[j]
          // }
          deepCopy(newobj[k], item)
        } else if (item instanceof Object) {
          // 2.如果item是对象
          newobj[k] = {}
          deepCopy(newobj[k], item)
        } else {
          // 3.都不是,则是简单数据类型
          newobj[k] = item
        }
      }
    }
    // 注意:数组要放在最前面判断,数组也属于对象。简单放最后,因为最终递归到最后一层都是简单数据类型
    deepCopy(o, obj)
    o.msg.age = 20
    console.log(o, obj, '深度拷贝')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值