详解JavaScript中map()和forEach()的异同

 更新时间:2024年02月03日 08:38:04   作者:为什么会变成这样呢  
在JavaScript中,map()和forEach()是两个常用的数组方法,它们都用于遍历数组,但在某些方面有一些关键的区别,本文将详细讨论这两种方法的异同,以帮助您更好地理解它们的用法和适用场景,需要的朋友可以参考下

前言

在JavaScript中,map()forEach()是两个常用的数组方法,它们都用于遍历数组,但在某些方面有一些关键的区别。本文将详细讨论这两种方法的异同,以帮助您更好地理解它们的用法和适用场景。

返回值

map() map()方法创建一个新数组,其中包含对原始数组的每个元素应用回调函数的结果。

const numbers = [1, 2, 3];
const doubled = numbers.map(num => num * 2);
// doubled: [2, 4, 6]

map()通过对每个元素执行回调函数来生成新数组,原始数组不会被改变。

forEach() forEach()方法仅用于迭代数组中的每个元素,而不返回新数组。它的主要目的是执行回调函数,而不关心返回值。

const numbers = [1, 2, 3];
numbers.forEach(num => console.log(num));
// 输出:1, 2, 3

由于map()返回一个新数组,因此它通常用于对原始数组进行转换,而原数组保持不变。而forEach()主要用于对数组元素进行迭代,执行一些操作,但不会创建新的数组。因此,在需要获取处理结果的情况下,map()更为合适。

可链性

map() 由于map()返回一个新数组,因此可以链式调用多个数组方法。

const numbers = [1, 2, 3];
const squaredAndDoubled = numbers.map(num => num * 2).map(num => num ** 2);
// squaredAndDoubled: [4, 16, 36]

forEach() forEach()方法返回undefined,不支持链式调用。

中断迭代

map() 由于map()返回一个新数组,您可以通过在回调函数中使用return语句来提前终止迭代。

const numbers = [1, 2, 3, 4, 5];
const squared = numbers.map(num => {
  if (num > 3) return;
  return num ** 2;
});
// squared: [1, 4, 9, undefined, undefined]

forEach() forEach()无法提前终止迭代。 如果需要中断,可以通过在回调函数中抛出异常。

const numbers = [1, 2, 3, 4, 5];
try {
  numbers.forEach(num => {
    if (num > 3) throw BreakException;
    console.log(num);
  });
} catch (e) {}

性能

通常来说,map()的性能稍微低于forEach()因为map()需要创建一个新数组。

使用场景

map()的使用场景:

数据转换: 当需要对数组中的每个元素执行某种操作,并将结果组成一个新的数组时,map()是首选。

const numbers = [1, 2, 3];
const squared = numbers.map(num => num ** 2);
// squared: [1, 4, 9]

提取特定属性: 适用于从对象数组中提取特定属性形成新数组。

const users = [
  { id: 1, name: 'Alice' },
  { id: 2, name: 'Bob' },
  { id: 3, name: 'Charlie' }
];

const userIds = users.map(user => user.id);
// userIds: [1, 2, 3]

forEach()的使用场景:

迭代数组: 当只需要遍历数组执行某个操作,而不需要生成新的数组时,forEach()是更直接的选择。

const numbers = [1, 2, 3];
let sum = 0;

numbers.forEach(num => {
  console.log(num);
  sum += num;
});
// 输出:1, 2, 3
// sum: 6

操作全局变量: 可以在forEach()循环中更改外部变量的值。

const numbers = [1, 2, 3];
let sum = 0;

numbers.forEach(num => {
  sum += num;
});
// sum: 6

结论

总的来说,map()forEach()在某些方面有所不同,因此在选择使用它们时需要根据具体需求权衡其优缺点。如果需要生成一个新数组并对每个元素进行操作,则使用map();如果只是需要迭代数组并执行一些操作,而不关心返回值,则使用forEach()

以上就是详解JavaScript中map()和forEach()的异同的详细内容,更多关于JavaScript map()和forEach()异同的资料请关注脚本之家其它相关文章!

相关文章

  • Javascript结合css实现网页换肤功能

    Javascript结合css实现网页换肤功能

    现在网站换皮肤是比较常见的功能,大多数论坛都有的,要想实现这样效果可以看如下代码.
    2009-11-11
  • 微信小程序日历弹窗选择器代码实例

    微信小程序日历弹窗选择器代码实例

    这篇文章主要介绍了微信小程序日历弹窗选择器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 使用JS实现图片轮播的实例(前后首尾相接)

    使用JS实现图片轮播的实例(前后首尾相接)

    下面小编就为大家带来一篇使用JS实现图片轮播的实例(前后首尾相接)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • JavaScript生成.xls文件的代码

    JavaScript生成.xls文件的代码

    这篇文章主要介绍了JavaScript生成.xls文件的代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • 轻松搞定js表单验证

    轻松搞定js表单验证

    不用一行代码和一句提示语就搞定整个表单验证,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 基于Bootstrap实现图片轮播效果

    基于Bootstrap实现图片轮播效果

    这篇文章主要为大家详细介绍了基于bootstrap实现图片轮播效果的相关资料,具有一定的参考价值,感兴趣的朋友可以参考一下
    2016-05-05
  • js校验表单后提交表单的三种方法总结

    js校验表单后提交表单的三种方法总结

    本篇文章主要是对js校验表单后提交表单的三种方法进行了总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-02-02
  • 你不知道的 javascript【推荐】

    你不知道的 javascript【推荐】

    本文介绍了javascript中你所不知道的相关知识。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • JS实现倒计时和文字滚动的效果实例

    JS实现倒计时和文字滚动的效果实例

    这篇文章主要介绍了JS实现倒计时和文字滚动的效果,以实例的形式分析了倒计时与文字滚动效果的具体实现方法,并附有js时间变量的说明,非常具有实用价值,需要的朋友可以参考下
    2014-10-10
  • 第二次聊一聊JS require.js模块化工具的基础知识

    第二次聊一聊JS require.js模块化工具的基础知识

    第二次聊一聊JS require.js模块化工具的基础知识,本文为大家JS require.js模块化工具的最基本知识点,感兴趣的小伙伴们可以参考一下
    2016-04-04

最新评论