js 两个相等的数组,如何做到修改其中一个时,另一个不随着变化

var arrA = [1, 2, 3];
var arrB = arrA;

问题: 直接赋值时,若改变arrA,则arrB也会随着变化;若改变arrB,则arrA也会随着变化。

原因: js中array是引用类型,也就是arrA和arrB的原数据存储地址是一样的,arrA和arrB都是对原数据的引用,所以修改其中一个,另一个也会改变。这就好像是现在有一个房间,两扇门,AB两人分别从不同的门进去所看到的的房间是一样的,此时A拿走一个苹果,B会看到房间里少了一个苹果;B从外面带了一瓶饮料回到房间,A也会看到这个房间多了一瓶饮料。

解决方案: 那么两个相等的数组,修改其中一个怎么做到不改变另外一个呢?也就是说仅仅是arrA赋值给arrB,而不是把引用赋给它。

方法一: concat()用于连接两个或多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。
var arrB = [].concat(arrA);

方法二: 先JSON.stringify( ) 后 JSON.parse( )
var arrB = JSON.parse(JSON.stringify(arrA));

方法三: jQuery的extend方法
var arrB = $.extend(true, [], arrA);

方法四: Object.assign()方法 或者 […arr]
var arrB = Object.assign([], arrA);

方法五: […arr]
var arrB = […arrA];

注意: 如果是对象数组,即使是用方法一的concat、方法四的Object.assign()、方法五的[…arr]赋值也是会互相影响的!
var arrA = [{name:‘zhangsan’,age:20}];
var arrB = Object.assign([], arrA);       //或者 var arrB = […arrA]; 或者 var arrB = [].concat(arrA ) ;
arrB[0].age=25;
得: arrB → [{name:‘zhangsan’,age:25}] ;
         arrA → [{name:‘zhangsan’,age:25}];

对象数组用方法二的先JSON.stringify( ) 后 JSON.parse( )

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值