JavaScript中concat复制数组方法浅析
我们在需要进行数组复制的时候可能会想到以下的方法
代码
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()即可。
- JS数组合并push与concat区别分析
- js嵌套的数组扁平化:将多维数组变成一维数组以及push()与concat()区别的讲解
- JavaScript使用concat连接数组的方法
- JavaScript字符串对象的concat方法实例(用于连接两个或多个字符串)
- JS数组方法concat()用法实例分析
- JavaScript中使用concat()方法拼接字符串的教程
- 深入理解javascript中concat方法
- javascript使用 concat 方法对数组进行合并的方法
- Javascript连接多个数组不用concat来解决
- js采用concat和sort将N个数组拼接起来的方法
- javascript中数组的concat()方法使用介绍
- javascript concat数组累加 示例
- JS Array创建及concat()split()slice()的使用方法
- 浅谈JavaScript的push(),pop(),concat()方法
- JavaScript模拟数组合并concat
- JS数组降维的实现Array.prototype.concat.apply([], arr)
- javascript数组中的concat方法和splice方法
- JavaScript的concat方法实例代码(数组连接)
相关文章
javascript 中iframe高度自适应(同域)实例详解
这篇文章主要介绍了javascript 中iframe高度自适应(同域)实现代码的相关资料,需要的朋友可以参考下2017-05-05javascript学习笔记(七)利用javascript来创建和存储cookie
今天把javascript如何用来创建及存储cookie复习了一下,其中的一点体会拿出来和大家讨论,恳请高手指点一二。2011-04-04由document.body和document.documentElement想到的
不知道大家对这个标题有没有想法,反正此前我一直把他们混为了一谈。其实不然,首先需有个“标准”的概念。2009-04-04
最新评论