数组的浅/深拷贝

Posted zhaohui-116

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组的浅/深拷贝相关的知识,希望对你有一定的参考价值。

数组的浅拷贝

改变其中一个另外一个也会变化

直接赋值,var newArr = this.oldArr

数组的深拷贝

改变其中一个数组另一个数组不会变化

1.for循环方式

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

2.concat方法,连接两个数组,不会改变原始数组,返回一个副本

var arr1 = [1, 2, 3];
var arr2 = arr1.concat();
arr1[0] = 4;
console.log(arr1); //4, 2, 3
console.log(arr2); //1, 2, 3

3.slice方法,截取数组,

var arr1 = [1, 2, 3];
var arr2 = arr1.slice(0);
arr1[0] = 4;
console.log(arr1); //4, 2, 3
console.log(arr2); //1, 2, 3

4.ES6扩展运算符实现数组的深拷贝

var arr1 = [1, 2, 3];
var [...arr2] = arr1;
arr1[0] = 4;
console.log(arr1); //4, 2, 3
console.log(arr2); //1, 2, 

 

以上是关于数组的浅/深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

js的浅拷贝与深拷贝

JavaScript数组对象的浅拷贝与深拷贝深浅拷贝的区别+图解原理

JS的浅拷贝与深拷贝

C#的浅拷贝和深拷贝

面试官:说是Java中List的浅拷贝与深拷贝!

对象的浅拷贝与深拷贝