JS-扁平化数组

目录

1.递归

2.API

3.some方法

4.flat方法

5.lodash方法:_.flattenDeep(array)


1.递归

核心思路:循环遍历每一个数组元素 不是数组得数组元素先添加新数组中

 是数组得数组元素循环遍历 flat(数组元素)

 扁平化数组 数组排序 冒泡排序 插入排序 快速排序

var arr = [1,2,[3,4,5,[6,7,8,[9,10,[11,12]]]]];//[1,2,3,4,5,6,7,8,9,10]
function flat(arr){
	var newArr = [];
	for(var i=0;i<arr.length;i++){
		if(Array.isArray(arr[i])){
			newArr = newArr.concat(flat(arr[i]))
		}else{
			newArr.push(arr[i])
		}
	}
	return newArr;
}
console.log(flat(arr));

2.API

var arr = [1,2,[3,4,5,[6,7,8,[9,10,[11,12]]]]];//[1,2,3,4,5,6,7,8,9,10]
function flat(arr){
	// console.log(arr.toString().split(","));
	// var res = arr.toString().split(",");//["1","2","3","4"]
	// return  res.map(function(item){
	// 	return Number(item)
	// });
	return arr.toString().split(",").map(function(item){
		return +item
	})
}
console.log(flat(arr));

运行结果
[
   1,  2, 3, 4,  5,
   6,  7, 8, 9, 10,
  11, 12
]

3.some方法

var arr = [1,2,[3,4,5,[6,7,8,[9,10,[11,12]]]]];//[1,2,3,4,5,6,7,8,9,10]
function flat(arr){
	while(arr.some(function(item){
		return Array.isArray(item)
	})){
		console.log(arr,'上一次结果');
		arr = [].concat(...arr);//[1,2,[3,4,5,[6,7,8,[9,10]]]] // [1,2,3,4,5,[6,7,8,[9,10]]]
	}
	return arr
}
console.log(flat(arr));
var arr = [1,2,3,4,5];
// 拓展运算符 左侧展开
console.log(...arr);

运行结果:
[ 1, 2, [ 3, 4, 5, [ 6, 7, 8, [Array] ] ] ] 上一次结果
[ 1, 2, 3, 4, 5, [ 6, 7, 8, [ 9, 10, [Array] ] ] ] 上一次结果
[ 1, 2, 3, 4, 5, 6, 7, 8, [ 9, 10, [ 11, 12 ] ] ] 上一次结果
[ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, [ 11, 12 ] ] 上一次结果
[
   1,  2, 3, 4,  5,
   6,  7, 8, 9, 10,
  11, 12
]
1 2 3 4 5

4.flat方法

var arr = [1,2,3,[4,5,6,[7,8,9,[10,11]]]];
console.log(arr.flat(Infinity));

5.lodash方法:_.flattenDeep(array)

//引入lodash库 
 var _ = require('lodash');
 _.flattenDeep([1,[2,[3,[4]],5]]);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值