实现数组扁平化的几种方式
创始人
2024-11-14 04:09:12
0

目标: 实现数组扁平化[1,[2,[3,4,5]]] ==> [1,2,3,4,5]

我们有几种方法可以实现,分别为:

1、递归

function flatten(list){ 	return list.reduce((tar, cur) => { 		if(Array.isArray(cur)){ 			tar = tar.concat(flatten(cur)); 		} else { 			tar.push(cur); 		} 		return tar; 	}, []); } flatten([1,[2,[3,4,5]]]) // [1, 2, 3, 4, 5] 

递归的方法就是一直合并数组中是数组的元素,这里问题不大,这个方法适用于结构相对简单的数据,如果数据量特别的大,使用递归的话,回应性性能

2、toString方法

function flatten(list){     let str = list.toString();     return str.split(',').map(item => +item); } flatten([1,[2,[3,4,5]]]) // [1, 2, 3, 4, 5] 

使用toString方法可以将数组转化为数组内部元素的字符串,然后针对该字符串返回扁平化的数组,只是这种方法如果遇到包含对象的数组就不行了

3、正则表达式结合JSON

function flatten(list){     let newStr = JSON.stringify(list).replace(/\[|\]/g, '');     return JSON.parse(`[${newStr}]`); } flatten([1,[2,[3,4,5]]]) // [1, 2, 3, 4, 5] 

这个办法同样适用于结构相对简单的数组,如果遇到包含对象的数组就不行了

4、终极武器flat

[1,100,[2,[3,4,5]]].flat(3) // [1, 100, 2, 3, 4, 5] 

利用数组的flat方法可以实现数组的扁平化
flat() 方法创建一个新的数组,并根据指定深度递归地将所有子数组元素拼接到新的数组中。

flat传入的参数,指定要提取嵌套数组的结构深度,默认值为 1。
假使,我们不知道深度是多少的情况下,可以传入Infinity

[1,100,[2,[3,4,5]]].flat(Infinity) // [1, 100, 2, 3, 4, 5] 

另外,使用flat() 方法会忽略数组中的空槽。

[1,2,,3,,,,6].flat() // [1,2,3,6] 

所以,利用这个特性,我们还可以用它来删除数组的空槽数据哈!

记住吧!

相关内容

热门资讯

透视辅助!微信微乐小程序辅助器... 透视辅助!微信微乐小程序辅助器免费安装(辅助挂)好像存在有挂(详细辅助介绍教程);1、实时微信微乐小...
透视辅助!广西友乐免费辅助(辅... 透视辅助!广西友乐免费辅助(辅助挂)一贯真的是有挂(详细辅助必赢方法)1、广西友乐免费辅助透视辅助简...
透视辅助!好玩贰柒拾辅助(辅助... 透视辅助!好玩贰柒拾辅助(辅助挂)原来真的是有挂(详细辅助揭秘教程)1、好玩贰柒拾辅助ai辅助优化,...
透视辅助!丫丫陕西插件(辅助挂... 透视辅助!丫丫陕西插件(辅助挂)其实真的是有挂(详细辅助透视教程);1、每一步都需要思考,不同水平的...
透视辅助!途游游戏辅助脚本(辅... 透视辅助!途游游戏辅助脚本(辅助挂)都是存在有挂(详细辅助2025版教程);透视辅助!途游游戏辅助脚...
透视辅助!微信小程序蜀山四川血... 透视辅助!微信小程序蜀山四川血战辅助(辅助挂)本来真的有挂(详细辅助2025新版)1、下载好微信小程...
透视辅助!微信多乐跑得快辅助工... 透视辅助!微信多乐跑得快辅助工具(辅助挂)本来是真的有挂(详细辅助辅助教程)1、很好的工具软件,可以...
透视美元局!智星德州菠萝插件官... 透视美元局!智星德州菠萝插件官网,aapoker辅助挂,规律教程(有挂工具);智星德州菠萝插件官网辅...
透视辅助!闲聚辅助器(辅助挂)... 透视辅助!闲聚辅助器(辅助挂)果然是真的有挂(详细辅助技巧教程)所有人都在同一条线上,像星星一样排成...
透视黑科技!德普之星透视辅助软... 透视黑科技!德普之星透视辅助软件下载,aapoker脚本怎么用,黑科技教程(有挂细节)1、点击下载安...