深浅拷贝js高级

问题对对象直接复制,且在新的对象更改,不影响原对象?
        答:使用深浅拷贝


 

 浅拷贝:拷贝地址

拷贝对象: 展开运算符,Object.assgin()
拷贝数组:concat(),Object.assgin()

 const obj0={uname:'小白',age:20}
 const o ={...obj0}
 o.age=33
 console.log(o);//{uname: '小白', age: 33}
 console.log(obj0);//{uname: '小白', age: 20}

8d8dfe3b1a51401dae8990f2d7af36dc.png


 

 深拷贝:

  1. 拷贝对象,新的对象更改不影响原对象,通过递归来实现
  2. 在普通拷贝直接赋值,如果遇到数组形式,再次调用递归函数
  3. 如果遇到对象形式,再次调用递归函数把对象解决,先array后对象

 深拷贝有3种方法:

  1.  通过递归来实现深拷贝,return退出递归函数
  2.  js库lodash里面cloneDeep内部实现深拷贝
  3.  用JSON实现深拷贝

 

   //递归函数:在函数内部自己调用自己
          

  function getTime(){
                    document.querySelector('div').innerHTML=new Date().toLocaleString()
                    setTimeout(getTime, 1000);
                }
                getTime()

   //1.通过递归来实现深拷贝,return退出递归函数
       

 const obj={uname:'小欢',age:24,hobby:['跳舞','唱歌'],family:{mother:'pink妈妈'}}
        const nObj={}
        // //拷贝函数
        function DeepCopy(newObj,oldObj) {
            //遍历对象
            for (const k in oldObj) {
            if(oldObj[k] instanceof Array){
                newObj[k] =[]
                // oldObj[k] ['跳舞','唱歌']
                DeepCopy(newObj[k],oldObj[k])
            }else if(oldObj[k] instanceof Object){
                newObj[k] ={}
                DeepCopy(newObj[k],oldObj[k])
            }else{
                  //k 属性名   oldObj[k]属性值
              // newobj[k] ===newobj.uname
              newObj[k]=oldObj[k]
            }
            }
        }
        DeepCopy(nObj,obj)
        console.log(obj);
        nObj.uname ='小英'
        nObj.hobby[0]='民族舞'
        nObj.family.mother='red妈妈'
        console.log(nObj);

77d2c91ed5df4baea2acf9454827fd78.png
        //2.js库lodash里面cloneDeep内部实现深拷贝
        //3.用JSON实现深拷贝
 

    const obj1={uname:'小欢',age:24,hobby:['跳舞','唱歌'],family:{mother:'pink妈妈'}}
        //JSON.parse() JSON字符串转变对象,就是一个新的实例对象o1!==obj1
        const o1 =JSON.parse(JSON.stringify(obj1))
        o1.family.mother='red妈妈'
        console.log(obj1);//{uname:'小欢',age:24,hobby:['跳舞','唱歌'],family:{mother:'pink妈妈'}}
        console.log(o1);//{uname:'小欢',age:24,hobby:['跳舞','唱歌'],family:{mother:'red妈妈'}}

 7f8b2e5a71924874a51bc3c3fcddda73.png

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值