JavaScript多维数组扁平化的四种方法 前端面试题

本文介绍了JavaScript中实现多维数组扁平化为一维数组的四种方法,包括两种递归函数实现,一种利用toString、split和map的方法,以及使用ES6的扩展运算符。每种方法都有详细的解释和示例。
摘要由CSDN通过智能技术生成

所谓的数组扁平化就是将多维数组转成一维数组,例如:将多维数组 [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4] 转成[1, 2, 8, 6, 7, 3, 3, 6, 9, 4] 的形式,以下为数组扁平化的几种方法

方法一:通过递归函数实现1
// 多维数组
var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]

function getNewArr(arr) {
  // 定义新数组用于存储所有元素
  var newArr = []
  // 遍历原数组中的每个元素
  for (var i = 0; i < arr.length; i++) {
    // 判断当前元素是否为数组
    if (Array.isArray(arr[i])) {
      // 若当前元素为数组时,调用函数本身继续判断,通过 concat 方法连接函数返回的数组
      newArr = newArr.concat(getNewArr(arr[i]))
    } else { // 若不是数组直接将当前元素追加到新数组的末尾
      newArr.push(arr[i])
    }
  }
  // 循环结束将新数组返回
  return newArr
}

console.log(arr) // [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
console.log(getNewArr(arr)) // [1, 2, 8, 6, 7, 3, 3, 6, 9, 4]

方法二:通过递归函数实现2
var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
// 定义全局变量用于存储元素
var newArr = []

function getNewArr(arr, newArr) {
  // 遍历原始数组中的每一项
  for (var i = 0; i < arr.length; i++) {
    // 判断数组中的当前元素是否是数组
    if (Array.isArray(arr[i])) {
      // 是数组时继续调用函数进行判断
      getNewArr(arr[i], newArr)
    } else {
      // 否则将当前元素追加到新数组中
      newArr.push(arr[i])
    }
  }
}
// 调用函数
getNewArr(arr, newArr)
// 打印
console.log(newArr) //  [1, 2, 8, 6, 7, 3, 3, 6, 9, 4]

方法三:toString、split和map结合使用对数组进行扁平化;该方法有局限性数组中的元素必须都是数字,因为 toString 会将数组中的元素都转成字符串
var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]

function getNewArr(arr) {
  var newArr = arr.toString().split(',').map(function(item) {
    // 使用 + 号将当前元素转成数字
    return +item
  })

  return newArr
}

console.log(getNewArr(arr)) // [1, 2, 8, 6, 7, 3, 3, 6, 9, 4]

说明:

toString() 方法会将数组中的所有元素顺次拼接在一起作为一个字符串返回,元素之间会用 , 进行分割

var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
console.log(arr.toString()) // 1,2,8,6,7,3,3,6,9,

split() 会将字符串按照指定字符分割成数组元素,最终会返回一个字符串数组

var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
// 通过 , 号对字符串进行分割
console.log(arr.toString().split(','))//["1", "2", "8", "6", "7", "3", "3", "6", "9", "4"]

map() 该方法会顺次将数组中的元素传给处理函数,都处理完成后会作为新数组返回

var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
// 通过 , 号对字符串进行分割
console.log(arr.toString().split(',').map(function(item) { // 通过 item 参数接收传入的元素
	// 处理元素,并将此次处理结果返回
	return +item 
}))//[1, 2, 8, 6, 7, 3, 3, 6, 9, 4]

方法四:通过ES6中的 … 运算符
var arr = [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]
function getNewArr(arr) {

  // 循环数组中的元素判断元素是否为数组
  while(arr.some(item => Array.isArray(item))) {
    // 解构数组
    arr = [].concat(...arr)
  }

  return arr
}
console.log(getNewArr(arr)) // [1, 2, 8, 6, 7, 3, 3, 6, 9, 4]
console.log(arr) // [[1, 2, 8, [6, 7]], 3, [3, 6, 9], 4]

说明:

通过 ... 运算符只能解构一层数组,所以需要循环进行解构,直到数组中的所有数组都解构完成

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值