【JavaScript中数组的flatMap方法的详细介绍】

在我们平时对数组进行操作的时候,通常map、forEach和filter方法比较常用。而flatMap方法用得相对少一些。当你掌握了flatMap方法的使用之后,我相信你一定会喜欢上它的!

下面我们会通过以下三个问题展开对flatMap方法的讲解:

 1. flatMap是什么?
 2. 如何使用flatMap方法?
 3. flatMap方法结合实际场景的使用。
 
flatMap是什么?

 flatMap是数组的一个新方法,它会遍历原数组的每一个元素, 并且会为每个元素都执行一次传入的回调函数,最终把所有元素执行回调函数返回的结果压缩成一个新数组,flatMap会返回一个新的数组,不会改变原数组的元素。

参数:  
        callback:   

                遍历数组元素的时候,会为每一个元素都执行一次回调函数,可以传入三个参数:

                currentValue:当前正在数组中处理的元素。

                index:可选的。数组中正在处理的当前元素的索引。

                array:可选的。调用flatMap方法的数组。

如何使用flatMap方法?

flatMap能用于在遍历数组期间增加、删除和修改数组元素(也就是修改 items 的数量),当我们需要增加元素时,就在回调函数中返回一个包含多个元素的数组,如果想要删除某一个元素时,就在回调函数中返回一个空数组(注意是空数组,返回空字符串、null或者undefined都不会改变数组items 的数量),如果想要修改元素,则在回调函数中返回一个修改过后的元素即可。

增加元素:

	// 增加元素
	const msgArr = ["it's Sunny in", "California"];

	const newArr = msgArr.flatMap(i => i.split(' '))
	console.log(newArr); //   ["it's", "Sunny", "in", "California"]

删除元素:

    // 删除元素
	const arr = [1, 2, 3, 4]
	
	const newArr = arr.flatMap(x => x % 2 === 0 ? [x]: [])
	
	console.log(newArr); // [2, 4]

修改元素:

    // 修改元素
	const arr = [1, 2, 3, 4]
	
	const newArr = arr.flatMap(x => [x * 2])
	
	console.log(newArr); // [2, 4, 6, 8]

flatMap方法结合实际场景的使用:

下面我们来看一个实际的例子:例如我们现在有一个选择公司的Select下拉组件,但是后端接口返回的公司列表里面的每一项的字段和我们Select下拉组件需要的字段格式不一样,而且我们还有一个特殊的要求,就是已授权的公司我们才允许在Select下拉组件中选择。这时候我们就想办法遍历公司列表,然后先把未授权的公司过滤掉,然后再把每一项转换成Select下拉组件所需要的数据格式。

这是我们最后展示的公司下拉组件:

接口返回的公司列表数据结构如下:

	/**
	 * 后端接口返回的公司列表数据:
	 * 	Id: 公司的唯一ID
	 *  Name: 公司名称
	 * 	Authorized: 是否已经授权: 1:已授权,2:未授权
	 * 
	 */
	
	const studioList = [
		{
			Authorized: "2",
			CompanyType: "1",
			Id: "3729",
			Name: "阿我打完的",
			ServiceProviderId: "6",
			TenantId: "1",
		},
		{
			Authorized: "1",
			CompanyType: "1",
			Id: "3134",
			Name: "纳税统计-启用时间202101无期初",
			ServiceProviderId: "6",
			TenantId: "1",
		},
		{
			Authorized: "1",
			CompanyType: "1",
			Id: "427",
			Name: "美丽人生工作室",
			ServiceProviderId: "6",
			TenantId: "1",
		},
		{
			Authorized: "1",
			CompanyType: "1",
			Id: "410",
			Name: "凭证测试专用2",
			ServiceProviderId: "6",
			TenantId: "1",
		}
	]	

 选择公司的Select下拉组件需要的数据格式如下:

    [
		{
			text: '公司名称',
			value: '公司ID'
		}
	]

接下来我们就需要把Authorized等于2的过滤掉,然后再转换成Select下拉组件需要的格式,

我们先使用filter配合map来实现:

const filterList = studioList.filter(r => r.Authorized === '1').map(i => ({text: i.Name, value: i.Id}))
	
// 最终也是可以得到我们想要的数据的:[{text: "纳税统计-启用时间202101无期初",value: "3134"},{text: "美丽人生工作室",value: "427"},{text: "凭证测试专用2",value: "410"}]
console.log(filterList);
	

但是使用filter配合map来实现看起来不是那么简洁易读,下面我们使用flatMap方法来替代:

const filterList = studioList.flatMap(r => r.Authorized === '1' ? [{text: r.Name, value: r.Id}] : [])
	

最终也是得到一样的结果的,但是flatMap用起来更简洁易读一些。

以上就是flatMap的简单介绍和使用啦,如果有写得不好的地方还望路过的大佬指出改正,每一次都是用心在做事,如果觉得这篇文章对你有帮助麻烦点个赞支持一下,谢谢!

### JavaScript 数组 `flatMap` 方法使用教程 #### 定义与特性 `flatMap` 是一种功能强大的数组方法,它结合了 `map()` 和 `flat()` 的操作,在对数组元素进行映射之后自动将其扁平化一层。这种方法特别适用于那些希望简化多层嵌套结构的数据集的情况[^1]。 #### 基本语法 该方法接受两个参数:一个是应用于每个元素上的回调函数;另一个是可选的对象作为执行上下文(`this`)。其基本形式如下所示: ```javascript array.flatMap(callback[, thisArg]) ``` 其中,`callback` 函数会接收三个参数——当前项、索引以及整个数组本身。而 `thisArg` 则定义了当调用此回调时所使用的对象[^4]。 #### 实际案例分析 考虑这样一个例子,给定一个整数列表 `[55, 66, 77, 88, 99, 100]` ,如果想要创建一个新的数组来存储原数组中各元素与其对应位置组成的子数组,则可以利用 `flatMap` 来实现这一目标: ```javascript var list = [55, 66, 77, 88, 99, 100]; var newArr = list.flatMap((item, index) => [item, index]); console.log(newArr); // 输出: [55, 0, 66, 1, 77, 2, 88, 3, 99, 4, 100, 5] ``` 这里可以看到,相比于单独使用 `map()` 后再手动调用 `flat()`,直接采用 `flatMap()` 不仅减少了代码量还提高了性能效率[^2]。 另外值得注意的是,对于包含其他数组在内的复杂数据结构来说,`flatMap()` 能够很好地处理这些情况而不至于过度深入内部层次。比如下面这个例子展示了如何优雅地展开混合类型的输入序列: ```javascript const mixedArray = ['a', ['b', 'c'], 'd']; const result = mixedArray.flatMap(item => typeof item === "string" ? item.split('') : item ); console.log(result); // ["a", "b", "c", "d"] ``` 在这个实例里,字符串被拆分成字符列表,而现有的简单数值则保持不变,最终得到了期望的结果集合。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值