今天碰到一道面试题,如何将二维数组转化为一维 数组
问题是这样子的:[[0, 1], [2, 3], [4, 5]] 如何转化为 [0, 1, 2, 3, 4, 5]?
方法一:使用ES5的reduce
reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值。
arr.reduce(callback,[initialValue]) callback
(执行数组中每个值的函数,包含四个参数)1:
previousValue
(上一次调用回调返回的值,或者是提供的初始值(initialValue))2:
currentValue
(数组中当前被处理的元素)3:
index
(当前元素在数组中的索引)4:
array
(调用 reduce 的数组)initialValue (作为第一次调用 callback 的第一个参数。)
var arr=[[0,1],[2,3],[4,5]];var onearr=arr.reduce(function(a,b){return a.concat(b);})console.log(onearr);//[0,1,2,3,4,5]
方法二:使用apply()
语法:
apply([thisObj[,argArray]])
定义:应用某一对象的一个方法,用另一个对象替换当前对象
var arr=[[1,2],[3,4],[5,6]];var onearr=[].concat.apply([],arr);console.log(onearr);//[0,1,2,3,4,5]
方法三:使用Array.prototype.flat()
flat() 方法会递归到指定深度将所有子数组连接,并返回一个新数组
语法:var newArray = arr.flat(depth)
,参数说明:depth
,可选,指定嵌套数组中的结构深度,默认值为1
。flat()方法会移除数组中的空项。但undefined、null仍会保留。
var arr=[[1,2],[3,4],[5,6]];var onearr=arr.flat();console.log(onearr);//[0,1,2,3,4,5]
方法四:
通过将数组转变成字符串,利用
str.split(',')
函数把字符串分割到数组中实现,但是这样数字全都变成字符串了
var arr1 = [[0, 1], [2, 3], [4, 5]];第一种:var arr = (arr1 + '').split(',');利用+运算法在和字符串计算时会先转化为字符串,任何相加将其转为字符串第二种:var arr = arr.toString().split(',');第三种:var arr = arr.join().split(',');