js怎样实现数组的扁平化

js怎样实现数组的扁平化,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

    数组扁平化的方式

    什么是数组扁平化?

    数组扁平化:指将一个多维数组转化为一个一维数组。

    例:将下面数组扁平化处理。

    const arr = [1, [2, 3, [4, 5]]] // ---> [ 1, 2, 3, 4, 5 ]

    1.使用flat()

    flat() 方法是ES10提出的,它会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。(flat意为“水平的;平坦的”)

    const result1 = arr.flat(Infinity) // 指定深度为无限
    console.log(result1) // [ 1, 2, 3, 4, 5 ]
    const result2 = arr.flat(1) // 指定深度为1
    console.log(result2) // [ 1, 2, 3, [ 4, 5 ] ]
    const result3 = arr.flat(2) // 指定深度为2
    console.log(result3) // [ 1, 2, 3, 4, 5 ]

    2.使用正则

    以下做法得到的数组元素都会变成字符串,不建议使用;

    const result1 = JSON.stringify(arr).replace(/\[|\]/g, '').split(',')
    console.log(result1) // [ '1', '2', '3', '4', '5' ] 数组元素都变成了字符串

    对以上方法进行优化处理;

    const result2 = JSON.parse('[' + JSON.stringify(arr).replace(/\[|\]/g, '') + ']')
    console.log(result2) // [ 1, 2, 3, 4, 5 ]

    3.使用reduce()+concat()

    使用reduce拿到数组的当前值和前一项值,判断当前值是否为数组,初始值设置为[],然后使用concat进行数组合并。

    • reduce()方法:对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值。

    • concat()方法:用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。

    function flatten(arr) {
      return arr.reduce((pre, current) => {
        return pre.concat(Array.isArray(current) ? flatten(current) : current)
      }, [])
    }
    const result = flatten(arr)
    console.log(result) // [ 1, 2, 3, 4, 5 ]

    4.使用函数递归

    循环遍历数组,发现含有数组元素就进行递归处理,最终将数组转为一维数组。

    const result = []
    function exec(arr) {
      arr.forEach(item => {
        if (Array.isArray(item)) {
          exec(item)
        } else {
          result.push(item)
        }
      })
    }
    exec(arr)
    console.log(result) // [ 1, 2, 3, 4, 5 ]

    5.使用扩展运算符+concat()

    ES6新推出的扩展运算符能对数组进行降维处理(一次降一维),循环判断是否含有数组,进行concat合并。

    some()方法:测试数组中是不是至少有1个元素通过了被提供的函数测试(它返回的是一个Boolean类型的值)。

    function flatten(arr) {
      while (arr.some(item => Array.isArray(item))) {
        arr = [].concat(...arr)
      }
      return arr
    }
    const result = flatten(arr)
    console.log(result) // [ 1, 2, 3, 4, 5 ]

    关于js怎样实现数组的扁平化问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注蜗牛博客行业资讯频道了解更多相关知识。

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    评论

    有免费节点资源,我们会通知你!加入纸飞机订阅群

    ×
    天气预报查看日历分享网页手机扫码留言评论电报频道链接