JS如何使用map、filter过滤数组并去除其中undefined的元素

业务背景

有一个下拉框的options需要过滤后再手动组装key和value。


不废话,上代码

let optionsDatas = properties.map(item => {
	// 添加过滤条件(type属于arr中的数据需要被剔出)
	let arr = ['object', '...'];
	if (!arr.includes(item.valueType.type)) {
		return {
			// 组装数据格式(一个下拉框数据要一个key和一个value)
			title: item.name,
			key: item.id,
		};
	}
}).filter(item2 => item2 !== undefined); // * 使用filter去除map中undefined的元素
// 将处理好的下拉框展示数据传值至组件
setPropertySelectData(optionsDatas);

遇到的错误

刚开始在.map的最后没有加上.filter过滤,
发现.map后的存在undefined的数据,结果报错了。
在这里插入图片描述

在这里插入图片描述
这是由于:
map的返回的数组的长度与源数据的长度相同,
如果某一项没有return 则返回undefined;


总结

  1. 使用map遍历数组后,再用filter方法过滤去除undefined的元素;
  2. 如果想要得到的数据与源数据没有差别(属性都是相同的),直接使用filter操作。

### 回答1: 可以使用`Array.prototype.map()`方法和`Array.prototype.filter()`方法结合使用过滤数组并返回符合条件元素的下标。下面是一个示例代码: ```javascript const arr = [10, 20, 30, 40, 50]; const filteredIndexes = arr.map((element, index) => ({ element, index })) .filter(({ element }) => element > 30) .map(({ index }) => index); console.log(filteredIndexes); // [3, 4] ``` 首先使用`map()`方法将每个元素和其下标打包成一个对象,然后使用`filter()`方法过滤出大于30的元素,最后使用`map()`方法仅返回符合条件的元素下标。 这里使用了箭头函数和对象解构语法,需要注意的是,`map()`和`filter()`方法返回的都是新数组,不会修改原数组。 ### 回答2: 在JavaScript中,可以使用`filter`方法过滤数组并返回下标。 `filter`方法是Array对象的内置方法之一,它接受一个回调函数作为参数,该回调函数会在数组的每个元素上执行,并根据返回值来决定是否保留该元素。 要返回下标,可以在回调函数中使用第二个参数`index`来获取当前元素数组中的索引。假设我们有一个数组`arr`,我们想要过滤出满足某个条件的元素,并返回对应的下标数组,可以像下面这样使用`filter`方法: ```javascript const arr = [1, 2, 3, 4, 5]; const filteredIndices = arr.filter((el, index) => { // 过滤条件,这里只保留奇数元素 return el % 2 === 1; }).map((el, index) => { // 返回元素下标 return index; }); console.log(filteredIndices); // 输出 [0, 2, 4] ``` 在上面的代码中,我们使用`filter`方法过滤出了数组中的奇数元素(回调函数返回值为`true`),然后使用`map`方法将每个元素的下标保存到新的数组`filteredIndices`中。最后,我们可以通过`console.log`输出结果。 使用`filter`过滤数组并返回下标的主要思路就是利用`filter`方法的回调函数中的第二个参数`index`来追踪元素的索引位置。根据不同的判断条件可以过滤出我们需要的元素,并将对应的下标保存起来。 ### 回答3: 在JavaScript中,可以使用Array的filter方法来过滤数组元素。然而,filter方法默认只返回满足条件的元素值,而不是它们在数组中的下标。如果我们想返回满足条件的元素数组中的下标,可以使用forEach方法来实现。 首先创建一个空数组,用于保存满足条件的元素的下标。然后使用forEach方法遍历数组,对每个元素进行条件判断。如果满足条件,将当前元素的下标添加到新数组中。最后返回新数组即可。 以下是一个例子: ```javascript function filterIndexes(arr, condition) { let indexes = []; arr.forEach(function(element, index) { if (condition(element)) { indexes.push(index); } }); return indexes; } let arr = [1, 2, 3, 4, 5]; let filteredIndexes = filterIndexes(arr, function(element) { return element % 2 === 0; // 过滤出偶数元素的下标 }); console.log(filteredIndexes); // 输出 [1, 3] ``` 在上述例子中,我们定义了一个名为filterIndexes的函数,它接受两个参数:一个数组arr和一个条件condition。通过调用filterIndexes函数并传入一个条件函数,我们可以获得满足条件的元素的下标数组。在这个例子中,我们过滤出了数组中的偶数元素的下标,并将结果打印到控制台上。 希望上述回答对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值