JavaScript中concat复制数组方法浅析
程序员文章站
2022-06-20 09:29:21
我们在需要进行数组复制的时候可能会想到以下的方法
代码
var arr1 = [1,2,3,4,5];
var arr2 = [];
arr2 =...
我们在需要进行数组复制的时候可能会想到以下的方法
代码
var arr1 = [1,2,3,4,5]; var arr2 = []; arr2 = arr1; console.log(arr1); console.log(arr2);
执行结果如下:
[1, 2, 3, 4, 5] [1, 2, 3, 4, 5]
在这个例子中,将数组arr1赋值给了另一个数组arr2。
查看执行结果,似乎复制了数组的内容并创建了相同的数组。
但是,由于数组是“引用类型”的数据,因此它不会复制该值,而只是共享存储该值的内存的位置。
因此,我们编写以下代码
arr2.push(6); console.log(arr1); console.log(arr2);
执行结果如下
[1, 2, 3, 4, 5, 6] [1, 2, 3, 4, 5, 6]
根据以上结果可以发现即使我们只给arr2添加新值6,但是数组arr1中也会添加一个6,这就是因为两个
数组都只引用存储值的位置,如果更改任一数组中的数据,两者都会改变。
所以下面我们就来使用concat方法复制数组
我们来看具体示例
var arr1 = [1,2,3,4,5]; var arr2 = []; arr2 = arr1.concat(); arr2.push(6); console.log(arr1); console.log(arr2);
执行结果如下
[1, 2, 3, 4, 5] [1, 2, 3, 4, 5, 6]
要将另一个数组复制到数组arr2,只需要在复制源arr1中执行concat()即可。
下一篇: 网站运营建议和网站优化建议
推荐阅读
-
JavaScript中数组Array方法详解
-
JavaScript中创建数组的方法
-
在Javascript中处理数组之toSource()方法的使用
-
在JavaScript中处理数组之reverse()方法的使用
-
向JavaScript的数组中添加元素的方法小结
-
在JavaScript中操作数组之map()方法的使用
-
JavaScript中数组的常用方法
-
javaScript删除对象、数组中的null、undefined、空对象、空数组方法
-
javascript中FOREACH数组方法使用示例
-
RPGMAKER游戏引擎基于JavaScript的插件制作(六)——重写方法(三):在场景(scenes)中创建精灵(Sprite)——复制式重写的实例教学