导读:本期聚焦于小伙伴创作的《JS数组如何扁平化?JavaScript数组扁平化方法flat与递归实现教程》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《JS数组如何扁平化?JavaScript数组扁平化方法flat与递归实现教程》有用,将其分享出去将是对创作者最好的鼓励。

数组扁平化是JavaScript开发中处理嵌套数组的常用操作,目的是将多层嵌套的数组结构转换为只有一层的一维数组,方便后续的数据遍历、筛选等处理。在实际开发中,我们经常会遇到后端返回的多层嵌套数组数据,这时候就需要用到数组扁平化的方法。

JS数组如何扁平化?JavaScript数组扁平化方法flat与递归实现教程

什么是数组扁平化

数组扁平化也叫数组降维,简单来说就是把类似[1, [2, [3, [4]], 5]]这样的嵌套数组,转换成[1, 2, 3, 4, 5]这样的一维数组。嵌套的层数没有固定限制,扁平化操作需要把所有层级的数组元素都提取到最外层数组中。

使用原生flat方法实现扁平化

ES6之后JavaScript数组新增了flat方法,专门用于数组扁平化操作,使用起来非常便捷。该方法接收一个参数,表示需要扁平化的层级深度,默认值为1。

flat方法的基本用法

当不知道数组具体嵌套多少层时,可以传入Infinity作为参数,直接将所有层级的嵌套数组都扁平化。

// 定义多层嵌套数组
const nestedArr = [1, [2, [3, [4, [5]]], 6]];
// 扁平化一层
const flatOneLevel = nestedArr.flat(1);
console.log(flatOneLevel); // 输出:[1, 2, [3, [4, [5]]], 6]
// 扁平化两层
const flatTwoLevel = nestedArr.flat(2);
console.log(flatTwoLevel); // 输出:[1, 2, 3, [4, [5]], 6]
// 扁平化所有层级
const flatAll = nestedArr.flat(Infinity);
console.log(flatAll); // 输出:[1, 2, 3, 4, 5, 6]

flat方法的注意事项

  • flat方法会跳过数组中的空位,不会保留空元素
  • 如果原数组没有嵌套结构,调用flat方法会返回原数组的浅拷贝
  • 该方法属于ES6新增特性,部分旧版本浏览器可能不支持,需要做兼容性处理

递归实现数组扁平化

如果需要兼容不支持flat方法的运行环境,或者想要深入理解扁平化的实现逻辑,可以自己用递归的方式实现数组扁平化功能。

基础递归实现

核心思路是遍历数组的每一个元素,如果当前元素是数组,就递归调用扁平化函数处理这个子数组,否则就把元素直接放到结果数组中。

function flattenArray(arr) {
    // 定义结果数组
    const result = [];
    // 遍历输入数组
    for (let i = 0; i < arr.length; i++) {
        const item = arr[i];
        // 判断当前元素是否为数组
        if (Array.isArray(item)) {
            // 如果是数组,递归扁平化后把结果合并到结果数组
            result.push(...flattenArray(item));
        } else {
            // 如果不是数组,直接加入结果数组
            result.push(item);
        }
    }
    return result;
}
// 测试代码
const testArr = [1, [2, [3, [4]], 5]];
const flattened = flattenArray(testArr);
console.log(flattened); // 输出:[1, 2, 3, 4, 5]

递归实现的优化版本

上面的基础版本每次递归都会创建新的数组,效率上有优化空间,可以改成传入结果数组作为参数,减少数组创建次数。

function flattenArrayOptimized(arr, result = []) {
    for (let i = 0; i < arr.length; i++) {
        const item = arr[i];
        if (Array.isArray(item)) {
            // 递归处理子数组,把结果直接追加到传入的result数组
            flattenArrayOptimized(item, result);
        } else {
            result.push(item);
        }
    }
    return result;
}
// 测试代码
const testArr2 = [1, [2, [3, [4]], 5]];
const flattened2 = flattenArrayOptimized(testArr2);
console.log(flattened2); // 输出:[1, 2, 3, 4, 5]

两种方法的对比

对比维度flat方法递归实现
使用便捷性一行代码即可完成,无需额外逻辑需要编写额外函数,代码量更多
兼容性仅支持现代浏览器,旧环境不兼容所有支持ES5的环境都可以运行
执行效率底层实现优化较好,效率更高自定义实现效率略低,优化后接近原生
灵活性仅支持按层级扁平化,无法自定义处理逻辑可以在递归过程中添加自定义处理规则

实际开发中的选择建议

如果项目不需要兼容旧版本浏览器,优先使用原生的flat方法,代码更简洁,执行效率也更高。如果需要兼容旧环境,或者需要在扁平化过程中对元素做额外的处理,比如过滤某些值,就可以选择递归实现的方式,自定义处理逻辑更灵活。

JavaScript数组扁平化flat方法递归实现修改时间:2026-06-24 12:12:17

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。