【JS、数组】flat的基本用法

flat() 是 JavaScript 数组的一个方法,用于将嵌套的数组"扁平化"到指定的深度。默认情况下,flat() 会将数组扁平化一层(即深度为 1)。也可以通过传递一个参数来指定要扁平化的深度。

基本用法

javascript 复制代码
const arr = [1, [2, [3, [4, 5]]], 6];

// 默认深度为 1
const flatArr1 = arr.flat();
console.log(flatArr1); // 输出: [1, 2, [3, [4, 5]], 6]

// 指定深度为 2
const flatArr2 = arr.flat(2);
console.log(flatArr2); // 输出: [1, 2, 3, [4, 5], 6]

// 指定深度为 Infinity,完全扁平化
const flatArrInfinity = arr.flat(Infinity);
console.log(flatArrInfinity); // 输出: [1, 2, 3, 4, 5, 6]

参数

  • depth (可选):指定要扁平化的深度。默认值为 1。如果设置为 Infinity,则会将数组完全扁平化,直到所有嵌套的数组都被展开。

示例

示例 1: 默认深度为 1
javascript 复制代码
const arr1 = [1, [2, 3], [4, [5, 6]]];
const flatArr1 = arr1.flat();
console.log(flatArr1); // 输出: [1, 2, 3, 4, [5, 6]]
示例 2: 指定深度为 2
javascript 复制代码
const arr2 = [1, [2, [3, 4]], [5, 6]];
const flatArr2 = arr2.flat(2);
console.log(flatArr2); // 输出: [1, 2, 3, 4, 5, 6]
示例 3: 完全扁平化
javascript 复制代码
const arr3 = [1, [2, [3, [4, [5, 6]]]]];
const flatArr3 = arr3.flat(Infinity);
console.log(flatArr3); // 输出: [1, 2, 3, 4, 5, 6]

注意事项

  • flat() 方法不会改变原数组,而是返回一个新的扁平化后的数组。
  • 如果数组中包含非数组元素,flat() 会保留这些元素。

兼容性

flat() 方法在现代浏览器和 Node.js 中都得到了广泛支持,但在一些较旧的环境中可能不可用。如果你需要在不支持 flat() 的环境中使用它,可以使用 polyfill 或其他替代方法。

替代方法

如果你需要在不支持 flat() 的环境中实现类似的功能,可以使用递归函数:

javascript 复制代码
function flattenArray(arr, depth = 1) {
  return arr.reduce((acc, val) => {
    if (Array.isArray(val) && depth > 0) {
      acc.push(...flattenArray(val, depth - 1));
    } else {
      acc.push(val);
    }
    return acc;
  }, []);
}

const arr = [1, [2, [3, [4, 5]]], 6];
const flatArr = flattenArray(arr, Infinity);
console.log(flatArr); // 输出: [1, 2, 3, 4, 5, 6]
相关推荐
boooooooom4 分钟前
讲清 Proxy + effect + track/trigger 流程
javascript·vue.js·面试
leafyyuki20 分钟前
在 Vue 项目中玩转 FullCalendar:从零搭建可交互的事件日历
前端·javascript·vue.js
豆苗学前端1 小时前
彻底讲透浏览器缓存机制,吊打面试官
前端·javascript·面试
swipe1 小时前
箭头函数与 this 面试题深度解析:从原理到实战
前端·javascript·面试
进击的尘埃3 小时前
拖拽搭建场景下的智能布局算法:栅格吸附、参考线与响应式出码
javascript
小猪努力学前端3 小时前
基于PixiJS的试玩广告开发-续篇
前端·javascript·游戏
wuhen_n3 小时前
v-model 的进阶用法:搞定复杂的父子组件数据通信
前端·javascript·vue.js
wuhen_n3 小时前
TypeScript 深度加持:让你的组合式函数拥有“钢筋铁骨”
前端·javascript·vue.js
滕青山3 小时前
基于 ZXing 的 Vue 在线二维码扫描器实现
前端·javascript·vue.js
swipe4 小时前
深入理解 JavaScript 中的 this 绑定机制:从原理到实战
前端·javascript·面试