快速导航×

J*aScript 数组扁平化:flat() 与 flatMap() 方法解析2025-10-30 10:57:01
flat()用于扁平化嵌套数组,可指定深度或使用Infinity完全展开;flatMap()先映射后扁平化一层,适用于数据转换与合并场景。

javascript 数组扁平化:flat() 与 flatmap() 方法解析

J*aScript 中处理嵌套数组时,flat()flatMap() 是两个非常实用的方法。它们能帮助开发者更高效地将多维数组转换为一维结构,或在扁平化的同时进行数据映射。下面详细解析这两个方法的用法、区别及常见应用场景。

flat():数组扁平化的基本方法

flat() 方法用于将嵌套数组“拉平”,即递归到指定深度并将所有元素合并成一个新数组。它不会修改原数组,而是返回一个新的扁平化数组。

语法如下:

arr.flat([depth])

其中 depth 是可选参数,表示要展开的嵌套层数,默认值为 1。

示例:

const arr = [1, [2, [3, [4]], 5]]; console.log(arr.flat()); // [1, 2, [3, [4]], 5](默认展开一层) console.log(arr.flat(2)); // [1, 2, 3, [4], 5](展开两层) console.log(arr.flat(Infinity)); // [1, 2, 3, 4, 5](完全扁平化)

注意:flat() 会自动忽略数组中的空槽(empty slots),适合清理稀疏数组。

flatMap():先映射再扁平化

flatMap()map()flat() 的结合体。它先对每个元素执行 map 操作,然后将结果数组扁平化一层(depth=1),最终返回一个新数组。

万相营造 万相营造

阿里妈妈推出的AI电商营销工具

万相营造 168 查看详情 万相营造

语法:

arr.flatMap(callback)

callback 函数应返回一个数组或任意值。如果返回的是数组,则会被展开一层;如果是普通值,则保持不变。

示例:

const sentences = ['hello world', 'J*aScript flatMap']; const words = sentences.flatMap(str => str.split(' ')); // 结果: ['hello', 'world', 'J*aScript', 'flatMap']

另一个典型用途是添加额外元素:

const numbers = [1, 2, 3]; const doubledWithOriginal = numbers.flatMap(n => [n, n * 2]); // 结果: [1, 2, 2, 4, 3, 6]

flat() 与 flatMap() 的关键区别

  • 功能不同:flat() 只负责扁平化已有结构;flatMap() 先通过函数映射生成新结构,再扁平化一层。
  • 使用场景不同:需要深层展开时用 flat(depth);需要在转换数据的同时合并结果时优先考虑 flatMap()。
  • 性能差异:flatMap() 比先 map 再 flat 更高效,因为它只遍历一次数组,且仅支持一层扁平化,避免过度展开。

实际应用建议

在日常开发中,可以根据需求灵活选择:

  • 处理树形菜单或嵌套分类数据时,使用 flat(Infinity) 快速展平。
  • 文本分词、标签提取等场景下,flatMap() 能简洁实现拆分与合并。
  • 当 map 后返回的是数组,并希望将其“压平”时,优先使用 flatMap() 替代链式调用 map().flat()。

基本上就这些。掌握 flat() 和 flatMap() 的核心逻辑,能让数组操作更清晰、代码更简洁。

以上就是J*aScript 数组扁平化:flat() 与 flatMap() 方法解析的详细内容,更多请关注其它相关文章!


# 更受欢迎  # 常规营销推广价格优惠  # 献县网站优化排名  # 淮安网站建设解决方案  # 青岛学院网站建设  # 随州低成本网站优化价格  # 扎兰屯学校网站建设  # 新媒体营销与推广实训  # 曲靖网络营销推广运营公司  # 民航知识网站建设  # 赣州智能照明网站建设  # 有哪些  # javascript  # 它比  # 如何使用  # 链式  # 怎么做  # 的是  # 多维  # 递归  # 扁平化  # 区别  # java  # word 


相关栏目: 【 企业资讯168 】 【 行业动态20933 】 【 网络营销52431 】 【 网络学院91036 】 【 运营推广7012 】 【 科技资讯60970


相关推荐: Golang如何实现Web接口签名验证_Golang Web接口签名校验开发方法  taptap防沉迷怎么解除 taptap解除健康系统限制说明【2025最新】  QQ邮箱网页版登录入口 QQ邮箱官方在线使用平台  搜狗浏览器如何使用密码生成器创建强密码 搜狗浏览器内置密码安全工具  手机屏幕碎了但能正常使用怎么办 手机外屏碎裂的修复建议  必由学在线入口 必由学网页版快速登录入口  composer的"require-dev"部分是用来做什么的?  微信网页版官方入口教程 微信网页版网页版快速登录步骤  J*a中为什么不建议滥用继承_继承滥用带来的耦合与脆弱性问题  漫蛙漫画官方首页 漫蛙2漫画在线阅读入口  响应式容器内容自动缩放与宽高比维持教程  Golang如何实现状态模式管理对象状态_Golang State模式实现技巧  谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问  蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址  HTML5原生日期选择器与jQuery UI:实现日期选择器的联动与程序化控制  在VS Code中配置和运行Dart程序的完整步骤  一加Ace 6T实拍样张首次公布!李杰:主摄实力完全看齐4K档性能旗舰  火锅吃太多会怎样 火锅吃太多会上火吗  腾讯QQ邮箱官方网站_QQ邮箱网页版在线登录  百度网盘网页版入口 百度网盘网页版官方登录网址  快手官方唯一登录入口 谨防山寨钓鱼网站  win11开机启动修复循环怎么办 Win11无法进入系统高级启动解决方法【修复】  jQuery Mask 插件中实现电话号码固定前导零的教程  想当下一个《2077》?《心之眼》Steam评价升至"多半好评"  J*aScript中在Map循环中检测并处理空数组元素  j*a toString()的覆盖  CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示  J*a TimerTask中HashMap意外清空的深层原因与解决方案  Golang如何安装Swagger工具_GoSwagger文档生成环境  Android Studio计算器C键功能异常排查与修复教程  Eclipse怎么运行工程_Eclipse工程运行配置说明  Yandex官方入口网址 Yandex俄罗斯搜索引擎最新在线地址  ArrayList与LinkedList操作复杂度详解:遍历与修改  印象笔记如何设提醒任务防漏执行_印象笔记设提醒任务防漏执行【任务提醒】  深入理解字体排版:Adobe光学字偶距与CSS字偶距的差异与实现  三星ZFold5多任务卡顿_Samsung ZFold5流畅度提升  在J*a里如何理解依赖关系的方向_依赖方向在模块结构中的作用  CSS图片焦点样式实现教程:理解与应用tabindex属性  微博网页版官方账号登录 微博网页版内容浏览使用指南  c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架  深入理解J*aScript中的B样条曲线与节点向量生成  原创度检测工具有哪些?内容原创度检测工具前十名排名  纯CSS与HTML网格布局的HTML精简策略:SVG与JS方案解析  React Router v6 教程:构建认证保护的私有路由与重定向策略  漫蛙漫画官方主页入口 漫蛙MANWA网页直达访问链接  msn邮箱官网网页版入口 msn邮箱网页版官方链接  《燕云十六声》两周内达九百万玩家!位居畅销榜第五  Win11怎么开启高性能模式_Windows 11电源计划优化设置  Linux如何构建多环境配置管理_Linux多环境配置方案  小米Civi 4录制视频过暗_小米Civi 4亮度优化