1、用es5的reduce和concat组合
let list=[[1,2,3],[4,5,6],[7,8],[9]]let lists=list.reduce((a,b)=>a.concat(b))console.log(lists)
reduce的用法
数组方法reduce用来迭代一个数组,并且把他累积到一个值中。
使用 reduce 方法时,你要传入一个回调函数,这个回调函数的参数是一个 累加器 (比如例子中的 previousVal) 和当前值 (currentVal)。
reduce 方法有一个可选的第二参数,它可以被用来设置累加器的初始值。如果没有在这定义初始值,那么初始值将变成数组中的第一项,而 currentVal 将从数组的第二项开始。
使用 reduce 方法来让 array 中的所有值相加
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>reduce的使用</title>
</head>
<body><script>
var arr = [1, 2, 3, 4, 5];
sum = arr.reduce(function(prev, cur, index, arr) {//输出的是第一项的值或上一次叠加的结果,正在被处理的元素,正在被处理的元素的索引值console.log(prev, cur, index); return prev + cur;
})
console.log(arr, sum); //输入数组本身和最后的结果
</script>
</body>
</html>
concat的用法
concat()方法用于连接两个或多个数组,该方法不会改变现有的数组,而仅仅会返回被连接数组的一个新数组
语法
arrayObject.concat(arrayX,arrayX,…,arrayX)
返回值
返回一个新的数组。该数组是通过把所有 arrayX 参数添加到 arrayObject 中生成的。如果要进行 concat() 操作的参数是数组,那么添加的是数组中的元素,而不是数组。
例子 1
在本例中,我们将把 concat() 中的参数连接到数组 a 中:
二、用es6的flat扁平处理
let list = [[1,2,3],[4,5],[6,7,8],[9]]let lists = list.flat()console.log(lists)