前端 js 深拷贝/浅拷贝

浅拷贝 :

  • 浅拷贝,仅仅是指针给了另一个对象
 var obj = {
      name: '又双叒叕', age: 999, say() {
        console.log('强无敌');
      }
    };
    // 将指向obj1
      var obj1 = obj;
      // 值和obj 相等
      console.log(obj);
      console.log(obj1); 
打印如下

打印结果
如果修改obj的属性 那么obj1也会随之改变 可以理解成拿人手短 吃人嘴软

 obj1.name = '武大郎';
    console.log(obj);

在这里插入图片描述

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

有常用的三种深拷贝的方式
  1. 通过json实现, 但是会造成方法丢失
 var obj = {
      name: '又双叒叕', age: 999, say() {
        console.log('强无敌');
      }
    };
 var obj1 = JSON.stringify(obj);
    obj1 = JSON.parse(obj1);
    //console.log(obj1);
    obj.name = '小番茄';
    // 修改obj感受不到变化 但是obj不会受到影响
    console.log(obj1);

obj1 打印结果:

在这里插入图片描述
2. 通过for-in遍历循环,实现深拷贝

 var obj = {
      name: '又双叒叕', age: 999, say() {
        console.log('强无敌');
      }
    };
  var obj1 = {};
    for (var attr in obj) {
      obj1[attr] = obj[attr]
    }
    // console.log(obj1);
    obj1.say()
    //  修改obj
    obj.name = '哈希';
    console.log(obj1);  // 修改后还是原数据 不会受到影响
  1. 使用Object.assign()
 var obj = {
      name: '又双叒叕', age: 999, say() {
        console.log('强无敌');
      }
    };
        var obj1 = {};
    //将obj合并到obj1上
    Object.assign(obj1, obj);
    //console.log(obj1);
    obj1.age = 66;
    // 修改以后也是不会受到影响 
    console.log(obj);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值