深拷贝和浅拷贝

详细介绍什么是深拷贝浅拷贝

1.浅拷贝是把被拷贝的对象 复杂数据类型中的地址 拷贝给目标对象(地址的引用),修改目标对象 会影响 被拷贝对象;
2.深拷贝,完全克隆(拷贝的是对象,而不是地址),修改目标对象不会影响被拷贝对象
3. 通俗的讲:深拷贝拷贝,克隆后的对象会在内存另开辟内存,指针克隆后的对象指针指向新开辟的内存

在这里插入图片描述

一:浅拷贝;仅仅是指针给了另一个对象

 // 1.浅拷贝,仅仅是指针给了另一个对象,
    //2. 修改目标对象 会影响 被拷贝对象;
 var obj = {
      name: '厂长',
      age: 22,
      info: '野区养猪',
      say() {
        console.log(111111);
      }
    }
     var obj1 = obj;
    console.log(obj1); //{name: "厂长", age: 22, info: "野区养猪", say: ƒ}
    obj1.info = '打野'
    console.log(obj); //{name: "厂长", age: 22, info: "打野", say: ƒ}

二:深拷贝;两个对象之间没有任何关系

// 通过json实现深拷贝,会造成方法丢失  
var obj = {
      name: '厂长',
      age: 22,
      info: '野区养猪',
      say() {
        console.log(111111);
      }
    }
     var obj1 = JSON.stringify(obj);
    obj1 = JSON.parse(obj1);
    obj1.name = 'faker';
    //obj感受不到变化
    console.log(obj);//{name: "厂长", age: 22, info: "野区养猪", say: ƒ}
    console.log(obj1);//{name: "faker", age: 22, info: "野区养猪"}//方法丢失了
 // 通过for-in遍历循环,实现深拷贝
var obj = {
      name: '厂长',
      age: 22,
      info: '野区养猪',
    }
   
    var obj1 = {}
    for (var attr in obj) {
      obj1[attr] = obj[attr]
    }
    obj1.name = '骚猪PDD'
    console.log(obj);//{name: "厂长", age: 22, info: "野区养猪"}
    console.log(obj1);//{name: "骚猪PDD", age: 22, info: "野区养猪"}
//Object.assign()方法深拷贝
 var obj = {
      name: '厂长',
      age: 22,
      info: '野区养猪',
      say() {
        console.log(111111);
      }
    }
    var obj1 = {};
     //  将obj 合并到obj1上
     Object.assign(obj1, obj);
     // console.log(obj1);
     obj1.name = '若风',
       console.log(obj);//原对象感受不到变化原对象name属性没有变化
       //{name: "厂长", age: 22, info: "野区养猪", say: ƒ}
//三个点语法实现的对象深拷贝 
var obj = {
      name: '玩游戏',
      info: '吃鸡'
    }
    var obj1 = {
      ...obj
    }
    obj1.name = '和平精英'
    console.log(obj1);//拷贝的新对象{name: "和平精英", info: "吃鸡"}
    console.log(obj);//原对象没有变化{name: "玩游戏", info: "吃鸡"}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值