深拷贝浅拷贝 完善购物车

1.深拷贝 浅拷贝

1.1 浅拷贝

//针对的是数组和对象

        //浅拷贝  拷贝的是地址  对原数组也有影响

 let arr1 = [1,2,3,4];
        let arr2 = arr1;
        arr2.push(5);
        console.log(arr1);
        let obj1 = {a:1,b:2};
        let obj2 = obj1;
        obj2["c"] = 3;
        console.log(obj1);

1.2浅拷贝 拷贝的是值

        let arr1 = [1,2,3,4];
        let arr2 = [];
        for(let i=0;i<arr1.length;i++){
            arr2[i] = arr1[i];
        }
        arr2.push(5);
        console.log(arr1,arr2);

        let obj1 = {a:1,b:2};
        let obj2 ={};
        for(let i in obj1){
            obj2[i] = obj1[i];
        }

//对原数组有影响

       let obj1 = {a:[1],b:2};
        let obj2 ={};
        for(let i in obj1){
            obj2[i] = obj1[i];
        }
        obj2.c =3;
        obj2.a.push(2);
    console.log(obj1,obj2);

1.3封装深拷贝函数

      function deepCopy(obj) {
        let copyObj = null;
        if (Array.isArray(obj)) {
          copyObj = [];
        } else {
          copyObj = {};
        }

        for (let i in obj) {
          //判断是否引用类型
          if (typeof obj[i] == "object") {
            copyObj[i] = deepCopy(obj[i]);
          } else {
            copyObj[i] = obj[i];
          }
        }
        return copyObj;
      }
      //验证
      let obj1 = { a: [1], b: 2 };
      let obj2 = deepCopy(obj1);
      obj1.a.push(2);
      console.log(obj2); 

//实现深拷贝

 //[[1,[2,3]],[4],[5,[6]]] => [1,2,3,4,5,6]
      //实现深拷贝
      /*  let obj1 = { a: [1], b: 2 };
      let obj2 = JSON.parse(JSON.stringify(obj1));
      obj1.a.push(2);
      console.log(obj1, obj2); */

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值