当concat参数不为数组时,如上面的[1,2],4,5,则会将[1,2],4,5里面的参数若是基本类型则直接push进数组,如果是多维数组则只会拆开一层,而调用者数组不会改变,会原封不动的首先添加到新数组中。
可见arr2的改变并未影响新数组arr3;
当concat的参数是数组时,相当于遍历这个数组,将每一项值浅拷贝到新数组中因此原数组中某一个数组项(如下面的arr2)的改变会体现到新数组上。
var arr1 = [['a', 'b'], 'c']; var arr2 = [1,2]; var arr3 = [arr2,4,5]; var arr4 = arr1.concat(arr3); arr4; /** 0:["a", "b"] 1:"c" 2:(2) [1, 2] 3:4 4:5 **/现在改变arr2的值:
arr2.push(345); arr4; /** 0:(2) ["a", "b"] 1:"c" 2:(3) [1, 2, 345];//注意这里已经将arr2中新加入的值加入新数组中了 3:4 4:5 **/而当concat的参数为数组,且这个数组整体改变时不会影响新数组,还是上面的例子,现在更新arr3:
arr3.push(890); arr4; /** 0:["a", "b"] 1:"c" 2:(2) [1, 2] 3:4 4:5 **/arr4并没有变化。
1.
var newArr = Array.prototype.concat.apply([],arr);2.
var newArr = arr.reduce(function(prev,next){ retrun prev.concat(next); });3.
var newArr = [].concat(...arr);//注意扩展运算符只能扁平化一层数组4.
var reg = /[\[\]]/g; var str = JSON.stringify(arr); var arrstr = str.replace(reg,function(c,pos){ if(pos !== 0 && pos !== str.length - 1){ return ''; }else{ return c; } }); var newarr = JSON.parse(arrstr);