2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > js二维数组变为一维数组

js二维数组变为一维数组

时间:2022-02-05 15:54:31

相关推荐

js二维数组变为一维数组

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)

三、用apply实现

四、用call实现

五、用递归实现多维数组转化为一维数组

六、针对于简单的多维数组的转化

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。