javascript 数组处理的两个利器: `forEach` 和 `map`(下)

简介: javascript 数组处理的两个利器: `forEach` 和 `map`(下)

四、 forEachmap的比较

比较 forEachmap在功能和用途上的差异

forEachmap 是 JavaScript 中用于遍历数组的两个常用方法,它们在功能和用途上有以下差异:

  1. 功能:
  • forEach:用于遍历数组并对每个元素执行指定的操作,但不返回新的数组。它将回调函数应用到数组的每个元素上,并且可以使用 this 关键字来引用当前正在处理的元素。
  • map:也用于遍历数组并对每个元素执行指定的操作,但会返回一个新的数组,新数组的元素是对原数组元素应用操作后的结果。
  1. 返回值:
  • forEach:不返回值,它主要用于对数组进行迭代和操作,而不是创建新的数组。
  • map:返回一个新的数组,该数组包含了对原数组元素应用操作后的结果。
  1. 用法示例:
  • forEach 的示例:
const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function (number) {
  console.log(number);
});
  • map 的示例:
const numbers = [1, 2, 3, 4, 5];
const加倍后的数字 = numbers.map(function (number) {
  return number * 2;
});
console.log(加倍后的数字); 

综上所述,forEach 主要用于对数组进行迭代和操作,而 map 主要用于创建一个新的数组,其中包含对原数组元素应用操作后的结果。选择使用哪个方法取决于你的具体需求。如果你只需要遍历数组并执行某个操作,而不需要返回新的数组,可以使用 forEach。如果你需要根据操作结果创建一个新的数组,可以使用 map

讨论何时使用 forEach,何时使用 map

forEachmap 是 JavaScript 中用于遍历数组的两种常用方法。

它们都可以遍历数组中的每个元素,并对每个元素执行相应的操作。

但是,它们之间有一些重要的区别,这些区别决定了何时使用 forEach,何时使用 map

forEach

forEach 方法用于遍历数组中的每个元素,并对每个元素执行指定的操作。它是一个用于迭代的“只读”方法,它不会返回任何值,并且不能用于修改原始数组。

以下是一些使用 forEach 的常见场景:

  • 对数组进行遍历并执行某个操作,而不需要返回新的数组:
const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(number) {
  console.log(number);
});
  • 检查数组中的每个元素是否满足某个条件:
const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(number) {
  if (number % 2 === 0) {
    console.log(number + " 是偶数");
  } else {
    console.log(number + " 是奇数");
  }
});

map

map 方法也用于遍历数组中的每个元素,但与 forEach 不同的是,它会返回一个新的数组,该数组是对原始数组中每个元素应用操作后的结果。

以下是一些使用 map 的常见场景:

  • 将数组中的每个元素转换为另一种形式:
const numbers = [1, 2, 3, 4, 5];
const doubledNumbers = numbers.map(function(number) {
  return number * 2;
});
console.log(doubledNumbers); 
  • 对数组中的每个元素进行聚合计算:
const numbers = [1, 2, 3, 4, 5];
const sumNumbers = numbers.map(function(number) {
  return number + 10;
}).reduce(function(a, b) {
  return a + b;
}, 0);
console.log(sumNumbers); 

综上所述,何时使用 forEach,何时使用 map,取决于你的具体需求。如果你只需要遍历数组并执行某个操作,而不需要返回新的数组,可以使用 forEach。如果你需要根据操作结果创建一个新的数组,可以使用 map

分析两者在性能方面的差异

从性能方面来看,for循环的性能最好,其次是forEach,最后是map。这是因为for循环没有任何额外的函数调用栈和上下文,而forEach比想象中复杂,有诸多参数和上下文需要在执行时考虑,可能会拖慢性能;map最慢,因为它的返回值是一个等长的全新数组,数组创建和赋值会产生较大的性能开销。

在实际使用中,如果需要对数组进行简单遍历,推荐使用for循环或forEach方法;如果需要对数组进行复杂操作并返回新的数组,可以考虑使用map方法。需要注意的是,在数据量较大时,遍历性能的差距可能会更加明显,因此需要根据实际情况选择合适的遍历方式。

五、实际应用场景

介绍一些实际场景,展示如何在不同情况下选择使用 forEachmap

以下是一些实际场景,展示如何在不同情况下选择使用forEachmap

1. 简单的迭代操作: 如果你只需要对数组进行简单的迭代,并且不需要返回任何新的值,可以使用forEach。例如,打印数组中的每个元素:

const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(number) {
  console.log(number);
});

2. 对每个元素执行复杂的操作: 如果你需要对数组中的每个元素执行复杂的操作,但不需要返回新的数组,可以使用forEach。例如,将数组中的每个元素乘以 2:

const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(number) {
  number *= 2;
});

3. 返回新的数组: 如果你需要根据数组中的每个元素创建一个新的数组,可以使用map。例如,将数组中的每个元素加 1 并返回一个新的数组:

const numbers = [1, 2, 3, 4, 5];
const newNumbers = numbers.map(function(number) {
  return number + 1;
});
console.log(newNumbers); 

4. 同时使用 for 和 map: 如果你需要在迭代的同时创建一个新的数组,可以结合使用for循环和map。例如,将数组中的每个元素乘以 2 并将结果存储在新的数组中:

const numbers = [1, 2, 3, 4, 5];
const newNumbers = numbers.map(function(number) {
  return number * 2;
});
console.log(newNumbers); 

总之,选择使用forEach还是map取决于你的需求。如果你只需要简单的迭代操作,或者不需要返回新的值,可以使用forEach;如果你需要根据每个元素创建一个新的数组,可以使用map。有时,你可能需要结合使用for循环和map来达到你的目的。

六、 总结

总结 forEachmap的主要特点和用途

forEachmap都是 JavaScript 中用于遍历数组的方法,它们的主要特点和用途如下:

  1. forEach方法
  • 特点:
  • 对数组中的每个元素执行一次指定的操作。
  • 不返回新的数组,而是在遍历过程中直接修改原始数组。
  • 用途:
  • 适用于对数组进行简单的遍历和操作,例如打印每个元素、执行一些副作用操作等。
  • 不需要返回新的数组,或者不关心返回值的情况下使用。
  1. map方法
  • 特点:
  • 对数组中的每个元素执行一次指定的操作,并返回一个新的数组,其中包含操作后的结果。
  • 不会修改原始数组。
  • 用途:
  • 适用于将数组中的每个元素进行转换或操作,并返回一个新的数组。
  • 需要对数组进行映射操作,例如将每个元素乘以一个固定值、将字符串转换为数字等。

总的来说,forEach适用于简单的遍历和操作,不需要返回新的数组。而map适用于对数组进行转换操作,并返回一个新的数组。选择使用哪种方法取决于你的具体需求。

相关文章
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储
`map()`方法在什么场景下会比 `forEach()`方法更高效?
综上所述,当需要对数组元素进行复杂的转换并生成新数组、进行链式调用和函数式编程、处理元素之间存在明确映射关系的情况以及与其他数组方法结合使用时,`map()`方法比`forEach()`方法更高效,能够使代码更加简洁、清晰和易于维护。
271 32
|
数据采集 JavaScript 前端开发
JavaScript中通过array.filter()实现数组的数据筛选、数据清洗和链式调用,JS中数组过滤器的使用详解(附实际应用代码)
用array.filter()来实现数据筛选、数据清洗和链式调用,相对于for循环更加清晰,语义化强,能显著提升代码的可读性和可维护性。博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储 JavaScript 前端开发
如何选择使用`map()`方法和`forEach()`方法?
选择使用`map()`方法还是`forEach()`方法主要取决于操作的目的、是否需要返回值、代码的可读性和维护性等因素。在实际开发中,需要根据具体的业务需求和场景来灵活选择合适的方法,以实现更高效、更易读和更易维护的代码。
244 3
|
自然语言处理 前端开发 JavaScript
🛠️ JavaScript数组操作指南:20个精通必备技巧🚀
本文详细介绍了 JavaScript 中的 20 个高效数组操作技巧,涵盖了从基本的添加、移除元素,到数组转换和去重等高级操作。强调了不可变性的重要性,提供了清晰的代码示例,帮助开发者编写更整洁和高效的代码。无论是新手还是经验丰富的开发者,这些技巧都将显著提升您的编码能力,使您在项目中更具竞争力。
361 2
|
JavaScript 前端开发
JS将两个数组和合并成数组包对象格式的方法
JS将两个数组和合并成数组包对象格式的方法
351 0
|
JavaScript 前端开发 索引
JS遍历数组里数组下的对象,根据数组中对象的某些值,组合成新的数组对象
这篇文章介绍了如何在JavaScript中遍历数组里数组下的对象,并根据对象的某些属性值组合成一个新的数组对象。主要内容包括使用ES6的`for...of`循环来遍历数组对象,然后根据需要提取对象中的属性值,并将它们放入新的对象中,最终形成一个新的对象数组以供使用。
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
273 1
|
存储 JavaScript 前端开发
JavaScript Array(数组) 对象
JavaScript Array(数组) 对象
186 3