JavaScript 如何在一个数组上同时使用map和filter
filter()方法用来过滤数组中的值,而map()方法用来根据旧数组中的每一个值将一个新的值映射到另一个数组。
有时,我们需要同时使用filter()和map()方法。例如,我们想从数组中过滤所有的正数,并将它们的对数值映射到新的数组中。
在开始本教程之前,我们先看看filter()和map()方法的介绍。在本教程中,我们将学习如何用JavaScript在数组上同时使用map和filter方法。
array.filter()方法的语法
用户可以按照下面的语法来使用JavaScript的filter()方法。
在上面的语法中,我们将回调函数作为filter()方法的一个参数来传递。
array.map()方法的语法
用户可以按照下面的语法来使用JavaScript的map()方法。
在上述语法中,我们需要从map()方法的回调函数中返回数组元素。
参数
- element – 它是数组中的一个当前元素,同时使用filter()方法在数组中进行迭代。
-
index – 是该元素在数组中的索引。
-
self – 它是一个数组本身。
同时使用array.map()和array.filter()方法
本节将教我们在一个数组上同时使用filter()和map()方法。
语法
用户可以按照下面的语法来同时使用map()和filter()方法。
在上面的语法中,我们首先对数组使用了filter()方法,之后使用了map()方法。
例子1
在下面的例子中,数组包含正数和负数。我们把数组作为一个引用,并在数组上调用filter()方法来过滤数组中的所有正值。在filter()方法的回调函数中,如果数字大于0,我们返回true;否则返回false。
之后,我们使用map()方法,并返回每个被过滤元素的对数。用户可以看到,logarithmic_values数组只包含6个值,因为我们在过滤后的数组中删除了所有的负值。
例子2
在下面的例子中,我们创建了一个对象数组,数组中的每个对象都包含了雇员的ID、工作年限和工资。
之后,我们使用filter()方法来过滤所有经验大于3年的员工。接下来,我们使用map()方法将所有员工的工资增加50%,并将新的工资存储在new_salaries数组中。
在输出中,用户可以初步观察到增加后的总工资的总和。
用户通过各种例子学会了一起使用filter()和map()方法。在第一个例子中,我们用数字数组使用filter()和map()方法。在第二个例子中,我们也学会了用对象数组来使用filter()和map()方法。