首页 > 作文

js实现数组的扁平化

更新时间:2023-04-04 02:05:28 阅读: 评论:0

目录
数组扁平化的方式1.使用flat()2.使用正则3.昭通学校使用reduce()+concat()4.使用函数递归5.使用扩展运算符+concat()总结

数组扁平化的方式

什么是数组扁平化?

数组扁平化:指将一个多维数组转化为一个一维数组。

例:将下面数组扁平化处理。

const arr = [1, [2, 3, [4, 5]]] // ---> [ 1, 2, 3, 4, 5 ]

1.使用flat()

flat() 方法是es10提出的,它会按照一个可指定的深度递归遍擦车历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。(flat意为“水平的;平坦的”)

const result1 = arr.flat(infinity) // 指定深度为无限console.log(result1) // [ 1, 2, 3, 4, 5 ]const result2 = arr.flat(1) // 指定深度为1console.log(result2) // [ 1, 2, 3, [ 4, 5 ] ]const result3 = arr.flat(2) // 指定深度为2console.log(result3) // [ 1, 2, 3, 4, 5 ]

2.使用正则

40不惑

以下做法得到的数组元素都会变成字符串,不建议使用;

const result1 = json.stringify(arr).replace(/\[|\]/g, '').split(',')console.log(result1) // [ '1', '2', '3', '4', '5' ] 数组元素都变成了字符串

对以上方法进行优化处理;

const result2 = json.par('[' + json.stringify(arr).replace(/\[|\]/g, '') + ']')console.log(result2) // [ 1, 2, 3, 4, 5 ]

3.使用reduce()+concat()

使用reduce拿到数组的当前值和前一项值,判断当前值是否为数组,初始值设置为[],然后使用concat进行数组合并。

reduce()方法:对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值。concat()方法:用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。
function flatten(arr) {  ret清华美院官网urn arr.reduce((pre, current) => {    return pre.concat(array.isarray(current) ? flatten(current) : 静谥current)  }, [])}const result = flatten(arr)console.log(result) // [ 1, 2, 3, 4, 5 ]

4.使用函数递归

循环遍历数组,发现含有数组元素就进行递归处理,最终将数组转为一维数组。

const result = []function exec(arr) {  arr.foreach(item => {    if (array.isarray(item)) {      exec(item)    } el {      result.push(item)    }  })}exec(arr)console.log(result) // [ 1, 2, 3, 4, 5 ]

5.使用扩展运算符+concat()

es6新推出的扩展运算符能对数组进行降维处理(一次降一维),循环判断是否含有数组,进行concat合并。

some()方法:测试数组中是不是至少有1个元素通过了被提供的函数测试(它返回的是一个boolean类型的值)。

function flatten(arr) {  while (arr.some(item => array.isarray(item))) {    arr = [].concat(...arr)  }  return arr}const result = flatten(arr)console.log(result) // [ 1, 2, 3, 4, 5 ]

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注www.887551.com的更多内容!

本文发布于:2023-04-04 02:05:27,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/51baac84944fa60b493564bf38941cb2.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:js实现数组的扁平化.doc

本文 PDF 下载地址:js实现数组的扁平化.pdf

标签:数组   递归   元素   方法
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图