JS数组扁平化(数组降维、数组拍平)

2024-04-12 23:48

本文主要是介绍JS数组扁平化(数组降维、数组拍平),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

Array.prototype.flat()

  • 该方法返回一个新的数组,对原数据没有影响
  • flat() 不传参数时,默认扁平化一层
  • flat(参数) 传入一个整数时,这个整数代码想要扁平化的层数
  • 传入 <=0 的整数将不进行扁平化,返回原数组
  • 如果原数组有空位,Array.prototype.flat() 会跳过空位
const test = [1, [2, 3],[4, [5, [6]], 7]
]console.log(test);
//(3) [1, Array(2), Array(3)]// flat不传参数时,默认扁平化一层
const c1 = test.flat();
//并不会影响原数组,将返回一个扁平化后的新数组
console.log(c1);
//(6) [1, 2, 3, 4, Array(2), 7]// flat传入一个整数参数,整数即扁平化的层数
const c2 = test.flat(2);
console.log(c2);
//(7) [1, 2, 3, 4, 5, Array(1), 7]// Infinity 关键字作为参数时,无论多少层嵌套,都会转为一维数组
c3 = test.flat(Infinity);
console.log(c3);
// [1, 2, 3, 4, 5, 6, 7]// 传入 <=0 的整数将返回原数组,不扁平化
test.flat(0)
test.flat(-1)// 如果原数组有空位,flat()方法会跳过空位。
const c4 = [1, 2, 3, 4, 5, , ].flat();
console.log(c4);
//(5) [1, 2, 3, 4, 5]

自主实现flat完全扁平化

function flat(arr) {var res = [];// 遍历数组里的元素for (let cur of arr) {// 判断是否为数组if (Array.isArray(cur)) {// concat连接数组res = res.concat(flat(cur))} else {// 将cur添加到返回数组的末尾res.push(cur)}}return res;
}console.log(flat(test));
//(7) [1, 2, 3, 4, 5, 6, 7]

lodash的baseFlatten

在lodash中和数组扁平化相关的方法有三个,实际实现上都是对baseFlatten()函数的包装。

  • flatten()是对数组进行一层扁平化处理
  • flattenDeep()是对数组完全扁平化处理
  • flattenDepth()是对数组进行指定层级的扁平化处理

baseFlatten()

源码
核心代码:

function baseFlatten(arr, depth, result){result || (result=[]);if(arr === null) return result;for(const val of arr){if(depth>0 && Array.isArray(val)){if(depth>1){baseFlatten(val, depth-1, result);}else{result.push(...val);}}else{result[result.length] = val;}}return result;
}

(注:js …的使用)

flatten(一层扁平化)

function flatten(arr) {// 获取数组的lengthconst length = arr == null ? 0 : arr.length// 当length大于0时,调用baseFlatten方法,扁平化层级为1return length ? baseFlatten(arr, 1) : []
}

flattenDeep(完全扁平化)

function flatten(arr) {// 获取数组的lengthconst length = arr == null ? 0 : arr.length// 当length大于0时,调用baseFlatten方法,扁平化层级为INFINITY无限大return length ? baseFlatten(arr, INFINITY) : []
}

flattenDepth(指定层级的扁平化)

function flattenDepth(arr, dep) {// 获取数组的lengthconst length = arr == null ? 0 : arr.length// length为0,直接返回空数组if (!length) {return []}// 判断dep,当dep为undefined时取1,否则通过一个加运算符操作转换为number类型dep = dep === undefined ? 1 : +dep// 调用baseFlatten方法,扁平化层级为depthreturn baseFlatten(array, depth)
}

使用reduce方法

实现flatteDeep()

function flattenDeep(arr) { return Array.isArray(arr)? arr.reduce( (acc, cur) =>[...acc, ...flattenDeep(cur)] , []): [arr]
}

flatten() 和 flattenDepth()实现方法类似flatteDeep()

实现flat

function flat(arr, depth = 1) {return depth > 0 ? arr.reduce((acc, cur) => {if(Array.isArray(cur)) {return [...acc, ...flat(cur, depth-1)]}return [...acc, cur]} , []): arr
}

这篇关于JS数组扁平化(数组降维、数组拍平)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898574

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE