前端数组扁平化flat

本文介绍了JavaScript中将嵌套数组转换为单层数组的五种方法:数组自带的`flat`方法、正则替换、递归、`reduce`和栈实现。详细展示了每种方法的代码示例和工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// const arr = [1,[2,[3,[4,5]]],6]
//  方法一:数组自带的扁平化方法,flat的参数代表的是需要展开几层,如果是Infinity的话,就是不管嵌套几层,全部都展开
// console.log(arr.flat(3))
// console.log(arr.flat(Infinity))

// 方法二:使用正则
/**
 * 
 * 首先是使用 JSON.stringify 把 arr 转为字符串
 * 接着使用正则把字符串里面的 [ 和 ] 去掉
 * 然后再拼接数组括号转为数组对象 "[" + string + "]"
 * 
 */
// console.log(JSON.parse('['+ (JSON.stringify(arr).replace(/\[|\]/g,"")) + ']') );

// 方法三递归
// const result = [];
// function fn(array){
//   for(let i=0;i<array.length;i++){
//     if(Array.isArray(array[i])){
//       fn(array[i])
//     }else{
//       result.push(array[i])
//     }
//   }
//   return result
// }
// console.log(fn(arr))

// 方法四:使用 reduce
/**
 * reduce 方法: 可以用来给数组求和
 * concat() 方法用于连接两个或多个数组。
 * concat() 方法不会更改现有数组,而是返回一个新数组,其中包含已连接数组的值。
 */
// const newArr = (arr)=>{
//   return arr.reduce((pre, cur)=>{
//     return pre.concat(Array.isArray(cur) ? newArr(cur): cur)
//   },[])
// }
// console.log(newArr(arr))


// 方法五:使用栈的思想实现 flat 函数
// const arr = [1,[2,[3,[4,5]]],6]
// const myFlat = (arr)=>{
//   const result = [];
//   const stack = [].concat(arr)
//   while(stack.length){
//     let top = stack.pop();
//     if(Array.isArray(top)){
//       stack.push(...top)
//     }else{
//       result.unshift(top)
//     }
//   }
//   return result
// }
// console.log(myFlat(arr))


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值