深拷贝与浅拷贝

数据类型存储

JavaScript中存在两大数据类型
基本类型
引用类型

基本类型数据保存在在栈内存中
引用类型数据保存在堆内存中,引用数据类型的变量是一个指向堆内存中实际对象的引用,存在栈中

浅拷贝

浅拷贝,指的是创建新的数据,这个数据有着原始数据属性值的一份精确拷贝

如果属性是基本类型,拷贝的就是基本类型的值。如果属性是引用类型,拷贝的就是内存地址
即浅拷贝是拷贝一层,深层次的引用类型则共享内存地址

<script>
        let arr =[1,2,3]
        //深拷贝
        let arr2=JSON.parse(JSON.stringify(arr))
        
        arr2[0]=0
        console.log(arr)
        console.log(arr2)
      
      //也是深拷贝
        const video={like:10}
        const video2=video
        video2.like=1000
        console.log(video.like)
        console.log(video2.like)
            
        
    </script>

深拷贝

深拷贝
深拷贝开辟一个新的栈,两个对象属完成相同,但是对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性

常见的深拷贝方式有:
JSON.stringify() 结合 JSON.parse()
JSON.stringify:将一个 JS 值转为 JSON 字符串。
JSON.parse:将 JSON 字符串转成 JS 值或对象。

concat和slice是对一维数组是深拷贝
…只是对数组和对象的第一层进行深拷贝
Object.assign()只是对对象的第一层进行深拷贝

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值