利用es5
的arr.reduce(callback[, initialValue])
实现es6
var arr1 = [[0, 1], [2, 3], [4, 5]]; var arr2 = arr1.reduce(function (a, b) { return a.concat(b)} ); // arr2 [0, 1, 2, 3, 4, 5]
利用es6
数组
var arr1 = [[0, 1], [2, 3], [4, 5]]; function flatten(arr) { return [].concat( ...arr.map(x => Array.isArray(x) ? flatten(x) : x) ) } var arr2 = flatten(arr1); // arr2 [0, 1, 2, 3, 4, 5] 优势: 多维数组也能够 好比:var arr = [[1,2],3,[[[4], 5]]]
利用apply
实现app
var arr1 = [[0, 1], [2, 3], [4, 5]]; var arr2 = [].concat.apply([], arr1); // arr2 [0, 1, 2, 3, 4, 5]
经过将数组转变成字符串,利用str.split(',')
实现。缺点是数组元素都变字符串了es5
var arr1 = [[0, 1], [2, 3], [4, 5]]; var arr2 = (arr1 + '').split(','); var arr2 = arr.toString().split(','); var arr2 = arr.join().split(','); // arr2 ["0", "1", "2", "3", "4", "5"]
利用 ES 的最新语法,Array.prototype.flat()。缺点是,有兼容性问题。优势是很是简单。prototype
mdn 上是这么描述的:flat() 方法会递归到指定深度将全部子数组链接,并返回一个新数组。code
语法:var newArray = arr.flat(depth)
,参数说明:depth,可选,指定嵌套数组中的结构深度,默认值为1。递归
举例:ip
var arr1 = [1, 2, [3, 4]]; arr1.flat(); // [1, 2, 3, 4] var arr2 = [1, 2, [3, 4, [5, 6]]]; arr2.flat(); // [1, 2, 3, 4, [5, 6]] var arr3 = [1, 2, [3, 4, [5, 6]]]; arr3.flat(2); // [1, 2, 3, 4, 5, 6] //Infinity展开全部嵌套数组 arr3.flat(Infinity); // [1, 2, 3, 4, 5, 6] var arr4 = [1, 2, , 4, 5]; arr4.flat(); // [1, 2, 4, 5]
特殊说明:flat()方法会移除数组中的空项。但undefined、null仍会保留。字符串
var arr = [1, 2, undefined , 4, 5, null]; arr.flat(); // [1, 2, undefined , 4, 5, null]
若有问题或建议,请多多赐教!get