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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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); //输出:4
alert(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()方法的区别的主要内容,如果未能解决你的问题,请参考以下文章

2017-5-30引用类型之Aray数组

引用类型之Array类型

JavaScript引用类型Array实例分析

引用类型之数组array最全的详解

java基础-引用数据类型之数组(Array)

JavaScript的进阶之路引用类型之Object类型和Array类型