flat()用于扁平化嵌套数组,可指定深度或使用Infinity完全展开;flatMap()先映射后扁平化一层,适用于数据转换与合并场景。

JavaScript 中处理嵌套数组时,flat() 和 flatMap() 是两个非常实用的方法。它们能帮助开发者更高效地将多维数组转换为一维结构,或在扁平化的同时进行数据映射。下面详细解析这两个方法的用法、区别及常见应用场景。
flat() 方法用于将嵌套数组“拉平”,即递归到指定深度并将所有元素合并成一个新数组。它不会修改原数组,而是返回一个新的扁平化数组。
语法如下:
arr.flat([depth])其中 depth 是可选参数,表示要展开的嵌套层数,默认值为 1。
立即学习“Java免费学习笔记(深入)”;
示例:
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() 是 map() 和 flat() 的结合体。它先对每个元素执行 map 操作,然后将结果数组扁平化一层(depth=1),最终返回一个新数组。
语法:
arr.flatMap(callback)callback 函数应返回一个数组或任意值。如果返回的是数组,则会被展开一层;如果是普通值,则保持不变。
示例:
const sentences = ['hello world', 'JavaScript flatMap']; const words = sentences.flatMap(str => str.split(' ')); // 结果: ['hello', 'world', 'JavaScript', 'flatMap']另一个典型用途是添加额外元素:
const numbers = [1, 2, 3]; const doubledWithOriginal = numbers.flatMap(n => [n, n * 2]); // 结果: [1, 2, 2, 4, 3, 6]在日常开发中,可以根据需求灵活选择:
基本上就这些。掌握 flat() 和 flatMap() 的核心逻辑,能让数组操作更清晰、代码更简洁。
以上就是JavaScript 数组扁平化:flat() 与 flatMap() 方法解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号