5种方式实现数组扁平化

文章介绍了将一个多维数组转换为一维数组的五种方法,包括toString和split结合、正则表达式、扩展运算符...和concat、reduce以及纯递归。这些方法针对不同场景和数据结构有不同的适用性。
摘要由CSDN通过智能技术生成

概念:将一个多维数组变为一维数组

[1,[2,3,[4,5]=>[1,2,3,4,5]

实现方式

  1. 利用toString&split将数组分割

注:该方法只适用于数组中没有对象元素,因为toStrin在转换时会将对象转为[Object Object]形式。

let arr = [1,[2,3,[4,5];
flatten1 (arr: any[]) {
    return arr.toString().split(',').map(item => {
      return parseInt(item);// 将字符串转换
     });
  }

console.log(this.flatten1(arr));
  1. 巧用正则

采用JSON.stringify方法先转换为字符串,然后通过正则表达式过滤掉字符串中的数组的方括号,最后再利用JSON.parse把它转换成数组

flatten2 (arr: any) {
    arr = '[' + JSON.stringify(arr).replace(/\[|\]/g, '') + ']';
    return JSON.parse(arr);
  }
  1. ES6扩展运算符...配合concat

ES6的扩展运算符...能通过迭代器拿出数组里的元素,concat在连接两个数组时也会拿出后一个数组里的元素

flatten3(arr: any) {
    while (arr.some((item: any) => Array.isArray(item))) {// 如果元素是数组就用...展开,直至没有数组
      arr = [].concat(...arr);
    }
    return arr;
  }
  1. reduce + 递归

reduce函数接受四个参数,分别为

  • previousValue (上一次调用回调返回的值,或者是提供的初始值(initialValue))

  • currentValue (数组中当前被处理的元素)

  • index(当前元素在数组中的索引)

  • array (当前调用的数组)

数组扁平化也需要数组的上一个元素和下一个元素连续操作,可以使用reduce+conact实现

flatten4(arr: any) {
    return arr.reduce((prev: any, curr: any) => {
      return prev.concat(Array.isArray(curr) ? this.flatten4(curr) : curr);
    }, []); // 这是prev的初始值
  }
  1. 纯正递归

普通递归的思路很容易理解,就是一遍一遍的去遍历数组,直到没有数组

 flatten5(arr: any) {
    let res: any[] = [];
    arr.map((item: any) => {
      if (item instanceof Array) {
        res = res.concat(this.flatten5(item));
      } else {
        res.push(item);
      }
    });
    return res;
  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值