JavaScript 如何在.map()中跳过一个元素
在JavaScript中,我们有时需要在使用map()方法时跳过数组元素。例如,我们需要在对元素进行一些数学运算后,将值从一个数组映射到另一个数组,只有当数组的值是有限的。
在这种情况下,用户可以在使用map()方法时使用下面的方法来跳过数组元素。
使用if-else语句
在array.map()方法中,我们可以使用if-else语句来跳过该元素。如果该元素满足if-else语句的条件,我们需要返回该元素进行映射;否则,我们可以返回一个null值。
语法
用户可以按照下面的语法在map()方法中使用if-else语句来跳过元素。
在上述语法中,如果if-else语句的条件评估为真,我们就返回某个值;否则,我们就返回null。
例子1
在下面的例子中,我们用数值创建了一个数组。我们的目标是将每个正数元素乘以2,并将它们映射到乘数数组中。在map()方法中,我们使用’元素>0’的条件检查数组是否为正数,如果评估为真,我们返回乘以2后的数字。
在输出中,用户可以看到,当我们返回空值时,该数组索引出现空。
将filter()方法与map()方法一起使用
我们可以在map()方法之前使用filter()方法。使用filter()方法,我们可以删除一些元素,并在另一个数组中过滤需要的元素。
之后,我们可以用filter()方法创建的数组来使用map方法,通过这种方式,我们可以间接地跳过map()方法中的元素。
语法
用户可以按照下面的语法来使用filter()方法来跳过map()方法中的元素。
在上面的语法中,首先,我们从数组中过滤数值,然后对过滤后的数值使用map()方法。
例2
在下面的例子中,我们创建了一个包含不同字符串值的数组。我们的目标是将所有字符串转换为大写字母,即第一个字符为大写字母。所以,首先,我们使用filter()方法来过滤所有大写第一个字符的字符串,并将它们存储在filteredValues数组中。
之后,我们将使用map()方法将这些字符串转换为大写字母后映射到一个新的数组。
使用array.reduce()方法
map()方法将元素映射到新的数组中。我们也可以使用reduce()方法实现同样的目的。我们可以取一个空数组,然后用reduce()方法将元素一个一个地映射到该数组中。
语法
用户可以按照下面的语法来使用reduce()方法,使其像map()方法一样工作,并跳过一些元素。
在上面的语法中,我们根据某个条件将元素推到数组中;否则,我们返回数组,而不将元素推到数组中,以跳过该元素。
例3
在下面的例子中, 我们的目标是将所有的元素映射到自己身上, 这些元素是可以被2除的.所以,我们将回调函数作为reduce()方法的第一个参数,将空数组作为第二个参数。
在回调函数中,如果条件得到满足,我们将元素推送到数组中并返回数组。否则,我们返回数组,不做任何改变。
最后,reduce()方法返回带有所有映射元素的数组,我们将其存储在final_array变量中,用户可以在输出中看到。
我们学习了三种方法来跳过map()方法中的一个元素。第一种方法是存储空元素,需要更多的空间,第二种方法增加了时间的复杂性,因为我们单独使用filter()方法。第三种方法是最好的,因为它的空间和时间都得到了优化。