浅拷贝以及深拷贝的简单理解

没写完,有点不知道怎么写才好理解

 

什么是Javascript拷贝?

个人理解,JavaScript的拷贝其实就像是对一个对象啊变量啊啥的进行复制,那为什么要复制?直接对原来的变量或对象啥的进行改动不就行了么,搞那么麻烦干嘛。

这是因为在工作中,有时候一个看似普通的变量,可能它会在多处被引用,如果你只在乎自己的代码能否运行,不在乎其他开发人员是否会因为你改动了一个数据导致系统出bug,那么你觉得你会不会被扣工资?

因此,对获取到的数据进行拷贝是很必要的,避免对源数据造成改动。

那什么是深浅拷贝?

拷贝的时候,按常理说,那就是复制啊,对吧,但是代码又不是跟现实一样运行的,虽然说是说拷贝,但有时候也就是拷贝了个壳,里面的内容还是会变的。

浅拷贝:说白了就是只能拷贝基本类型,涉及到对象数组这些引用类型的就只能复制个壳

示例一:

var a=1;
var b=a;
console.log(a,b) //a=1,b=1
b=4;
console.log(a,b) //a=1,b=4

在这里,我们将a的值赋给b,然后又把b的值给改成了4,那么a的值是不是会跟着改变,并没有,a的值还是1,嗯,那么这不就是拷贝了么,那为啥还有深浅之分?

看到上面的那句粗体写的话了吧,只能拷贝基本类型的就是浅拷贝,深拷贝的就是能将引用类型的数据一起拷贝过来的才算

那,怎么样的才算深拷贝,举个例子

示例二:

//第一步
var a={id:123};
var b=a;
console.log("a----",a,"b----",b)
//第二步
b.id=4;
console.log("a----",a,"b----",b)

一开始跟上面的例子差不多对吧,用b获取object类型的a的值,看起来是拷贝成功了吧,ok,我们看第二步的操作,在这里我们把b里边的id值进行修改,按上面那个例子来看的话,那输出的结果肯定也不会改变a的值吧,是吧,是这样想的吧,那就错咯

实际上输出的结果是 

看到了吧,这次改动后并不是跟 示例一 一样的,修改了b的id值,结果a的也跟着变化了,这样跟上面的浅拷贝不就不一样了么

那要怎么做才能深拷贝

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值