首页 > 代码库 > JavaScript引用类型之Array数组的concat()和push()方法的区别

JavaScript引用类型之Array数组的concat()和push()方法的区别

 在javascript中,我们一般都只用push向数组的尾部插入新元素的,但是其实在javascript中还有另外一个方法和push一样,也是向数组尾部插入新元素的,但是他们之间却存在着一定的区别,当我们看下面的代码的时候就明显的知道了:

 

1. 通过使用push操作数组:

 

技术分享

 

2. 通过使用concat操作数组:

 

技术分享

 

   

 

从上面的两个操作就很明显的看出来push和concat的区别了

push 遇到数组参数时,把整个数组参数作为一个对象插入;而 concat 则是拆开数组参数,一个元素一个元素地加进去。

push 直接改变当前数组;concat 不改变当前数组。 

下面通过代码证明上面的区别,代码如下:

 

<script>var colors=["red","blue","green"];var a={name:"张三"};var count=colors.push(a);alert(count); //输出:4alert(colors); //输出:red,blue,green,[object Object]colors=colors.concat(a);alert(colors[3]);//输出:red,blue,green,[object Object],[object Object]  显然concat将a集合拆分成name对象和"张三"对象,而push则是将a当成一个对象</script>

 

JavaScript引用类型之Array数组的concat()和push()方法的区别