Erlo

如何使用JavaScript中的concat方法复制数组

2019-01-19 18:01:16 发布   409 浏览  
页面报错/反馈
收藏 点赞
原文:http://www.php.cn/js-tutorial-414558.html
我们知道concat方法可以组合两个或多个数组以创建新数组,实际上concat方法也可以用来复制数组,本篇文章我们就来介绍关于JavaScript中concat方法复制数组的用法。

JavaScript

我们在需要进行数组复制的时候可能会想到以下的方法

代码

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()即可。

本篇文章到这里就全部结束了,更多精彩内容大家可以关注php中文网相关栏目教程!!!

登录查看全部

参与评论

评论留言

还没有评论留言,赶紧来抢楼吧~~

手机查看

返回顶部

给这篇文章打个标签吧~

棒极了 糟糕透顶 好文章 PHP JAVA JS 小程序 Python SEO MySql 确认