数组扁平化

最近学习es6,发现了一个东西很有意思

Array.prototype.flat()用于将嵌套的数组“拉平”,变成一维的数组。该方法返回一个新数组,对原数据没有影响。

  • 当没有参数时,flat默认只会“拉平”一层
[1, 2, [3, 4]].flat()
// [1, 2, 3, 4]
  • 当参数存在时,flat会拉平指定的层数
[12,[2,[3]]].flat(1)
(3) [12, 2, Array(1)]

[12,[2,[3]]].flat(2)
//(3) [12, 2, 3]
  • 如果不管有多少层嵌套,都要转成一维数组,可以用Infinity关键字作为参数。
[1, [2, [3]]].flat(Infinity)
// [1, 2, 3]
  • 如果用es5实现数组扁平化,就没有这么简单了
  1. reduce

我们用reduce函数进行遍历,把pre的初值赋值为[],如果当前的值是数组的话,那么我们就查看他的孩子,如果当前的值不是数组,那么我们就把它连进数组里。

function flat(arr){
	return arr.reduce(function(pre,cur){
		        return pre.concat(Array.isArray(cur) ? flat(cur) : cur);
	},[])
}
  1. toString & split

我们用toString方法取出数组的值,然后把取出的值用split拆分为数组,再用Number把数组中的每一个字符转换为数字

function flat(arr){
	arr.toString().split(',').map(function(item,index,arr){
		return Number(item)
	})
}
  1. join & split

和第二个方法的思想类似

function flatten(arr) {
    return arr.join(',').split(',').map(function(item) {
        return parseInt(item);
    })
}
  1. 递归

递归的遍历每一项,若为数组则继续遍历,否则concat

function flatten(arr) {
    var res = [];
    arr.map(item => {
        if(Array.isArray(item)) {
            res = res.concat(flatten(item));
        } else {
            res.push(item);
        }
    });
    return res;
}
  1. 扩展运算符

es6的扩展运算符能将二维数组变为一维,当arr中存在元素是数组,那么就要对arr使用一次拓展运算符进行降维。

function flatten(arr) {
    while(arr.some(item=>Array.isArray(item))) {
        arr = [].concat(...arr);
    }
    return arr;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值