如何跳过 .map() 中的元素?
在 JavaScript 中,我们有时需要在使用 map() 方法时跳过数组元素。例如,仅当数组值是有限的时,我们才需要在对元素执行一些数学运算后将值从一个数组映射到另一个数组。
在这种情况下,用户可以使用以下方法在使用map()方法时跳过数组元素。
使用 if-else 语句
在 array.map() 方法中,我们可以使用 if-else 语句来跳过该元素。如果该元素满足if-else语句条件,则需要返回该元素进行映射;否则,我们可以返回空值。
语法
用户可以按照以下语法使用if-else语句跳过map()方法中的元素。
array.map((number) => { if (condition) { // return some value } return null; })
在上面的语法中,如果 if-else 语句的条件评估为 true,我们将返回一些值;否则,我们返回 null。
示例 1
在下面的示例中,我们创建了包含数值的数组。我们的目标是将每个正元素与两个相乘并将它们映射到乘法器数组。在 map() 方法中,我们使用“element > 0”条件检查数组是否为正,如果计算结果为 true,则返回乘以 2 后的数字。
在输出中,用户可以看到当我们返回空值时,该数组索引显示为空。
<html> <body> <h2>Using the <i> if-else </i> statement to skip over element in the array.map() method</h2> <div id = "output"></div> </body> <script> let output = document.getElementById('output'); let array = [10, 20, 34, 4, 5, 6, 0, -1, 3, 2, 4, -2]; let multiplier = array.map((number) => { if (number > 0) { return number * 2; } else { return null; } }) output.innerHTML += "The final array after skipping the negative number in the map() method is - " + multiplier; </script> </html>
将filter()方法与map()方法结合使用
我们可以在map()方法之前使用filter()方法。使用filter()方法,我们可以删除一些元素并过滤另一个数组中所需的元素。
之后,我们可以将map方法与filter()方法创建的数组一起使用,这样我们就可以间接跳过map()方法中的元素。
语法
用户可以按照下面的语法使用filter()方法来跳过map()方法中的元素。
let filteredValues = array.filter((string) => { // filtering condition }) let str_array = filteredValues.map((element) => { // map value })
在上面的语法中,首先,我们从数组中过滤值,并对过滤后的值使用 map() 方法。
示例 2
我们在下面的示例中创建了一个包含不同字符串值的数组。我们的目标是将所有字符串转换为大写,其中第一个字符为大写。因此,首先,我们使用filter()方法过滤所有第一个字符为大写的字符串,并将它们存储在filteredValues数组中。
之后,我们将使用带有filteredValues数组的map()方法将它们转换为大写后将它们映射到一个新数组。
<html> <body> <h2>Using the <i> array.filter() </i> method to skip over element in the array.map() method.</h2> <div id = "output"></div> </body> <script> let output = document.getElementById('output'); let array = ["Hello", "hi", "JavaScript", "typescript", "C", "CPP", "html"]; let filteredValues = array.filter((string) => { if (string.charCodeAt(0) > 96 && string.charCodeAt(0) < 123) { return true; } return false; }) let str_array = filteredValues.map((element) => { return element.toUpperCase(); }) output.innerHTML += "The filtered values from the array are " + filteredValues + "<br/>"; output.innerHTML += "The final array after skipping some strings in the map() method is - " + str_array + "<br>"; </script> </html>
使用 array.reduce() 方法
map() 方法将元素映射到新数组。我们也可以使用reduce()方法来实现同样的目的。我们可以使用reduce()方法获取一个空数组并将元素一一映射到该数组。
语法
用户可以按照下面的语法使用reduce()方法来像map()方法一样工作并跳过一些元素。
let final_Array = numbers.reduce(function (array, element) { if (condition) { // perform some operation // push the final element to the array // return array } // return array }, []);
在上面的语法中,我们根据一定的条件将元素压入数组;否则,我们返回数组而不将元素推送到数组以跳过该元素。
示例 3
在下面的示例中,我们的目标是将所有可被二整除的元素映射到自身。因此,我们将回调函数作为reduce()方法的第一个参数传递,并将空数组作为第二个参数传递。
在回调函数中,如果满足条件,我们将元素推送到数组并返回数组。否则,我们将返回数组而不做任何更改。
最后,reduce() 方法返回包含所有映射元素的数组,我们将其存储在 Final_array 变量中,用户可以在输出中看到该变量。
<html> <body> <h2>Using the <i> array.reduce() </i> method to skip over element in the array.map() method.</h2> <div id = "output"></div> </body> <script> let output = document.getElementById('output'); let numbers = [10, 33, 34, 55, 57, 58, 90, 87, 85, 53]; let final_Array = numbers.reduce(function (array, element) { if (element % 2 == 0) { array.push(element); } return array; }, []); output.innerHTML += "The final array after skipping some strings in the map() method is - " + final_Array + "<br>"; </script> </html>
我们学习了三种在 map() 方法中跳过元素的方法。第一种方法存储空元素并占用更多空间,第二种方法增加了时间复杂度,因为我们单独使用filter()方法。第三种方法是最好的,因为它优化了空间和时间。