二维数组降维
第一种方法,使用for循环遍历数组
var arr = [1,2,[3,4],5,{a:1}];
var downArr = [];
for(var i=0;i<arr.length;i++){
for(var j=0;j<arr[i].length;j++){
downArr.push(arr[i][j]);
}
}
console.log(downArr); //downArr[1,2,3,4,5,{a:1}]
第二种方法,利用concat()不断合并原数组中的元素。
var arr = [1,2,3,[4,5],{a:1}];
var downArr = [];
for(var i=0;i<arr.length;i++){
downArr = downArr.concat(arr[i]);
}
console.log(downArr); //downArr = [1,2,3,4,5,{a:1}]
第三种方法,巧妙运用apply()的特性,apply可以把一个数组默认的转换为参数列表,然后再结合concat()。
var arr = [1,2,3,[4,5]];
function fun(arr){
return Array.prototype.concat.apply([],arr);
}
console.log(fun(arr)); //[1,2,3,4,5]
N维数组降维
我们知道多维数组不仅仅是二维,还有N维,当我们做N维数组降维的时候,因为我们不确定数组的维度,所以不能直接concat()来合并数组以达到降维的目的,这个时候就可以考虑使用递归的方法来实现。
var arr = [1,2,3,[4,5,6],[7,[8,9]],{a:1}];
var newArr = [];
function downArr(a){
for(var i=0;i<a.length;i++){
Array.isArray(a[i]) ? downArr(a[i]) : newArr = newArr.concat(a[i]); //判断原数组当前元素是否是数组,如果是那就再次调用本方法,如果不是就concat,直到循环完整个数组。
}
return newArr;
}
console.log(downArr(arr)); //[1, 2, 3, 4, 5, 6, 7, 8, 9, {a:1}]