我的编程空间,编程开发者的网络收藏夹
学习永远不晚

js中forEach的用法之forEach与for之间的区别

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

js中forEach的用法之forEach与for之间的区别

一、定义和用法

forEach() 调用数组的每个元素,并将元素传递给回调函数。

  • 注意: forEach() 对于空数组是不会执行回调函数的。

用法:

array.forEach(function(currentValue, index, arr), thisValue)

1==> currentValue    必需。当前元素
2==> index    可选。当前元素的索引值,是数字类型的
3==> arr    可选。当前元素所属的数组对象
4==> 可选。传递给函数的值一般用 "this" 值。
如果这个参数为空, "undefined" 会传递给 "this" 值

forEach 的注意点:

  • forEach() 本身是不支持的 continue break 语句的。
  • 我们可以通 return 语句实现 continue 关键字的效果

二、运用场景

1.运用的场景(计算数字之和)

计算数组所有元素相加的总和:

let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
let sum = 0;
arr.forEach((currentIndex, index, curArr) => {
    sum += currentIndex
        // sum=sum+currentIndex
})
console.log('之和是', sum);

2.运用的场景(给原始数组新增key值)

//给原始数组的每一项新增一个属性值
let arr = [{
  id: '001',
  name: '张三1'
}, {
  id: '002',
  name: '张三2'
}, {
  id: '003',
  name: '张三2'
}];
//给原始数组的每一项新增一个属性值
arr.forEach((item, index) => {
  item['addAttrs'] = ''
})
console.log('arr', arr);

--使用for of来出处理--
for (let item of arr) {
    item['index'] = ''
}
console.log('arr', arr);

三、forEach 跳出循环

1.forEach 跳出当前的循环 return

//内容为3,不遍历该项
var arr = [1, 2, 3];
arr.forEach(function(item) {
    if (item === 3) {
        return;
    }
    console.log(item);
});

2.forEach结合try跳出整个循环

  • 找到id为002,然后终止整个循环,返回当前这一项的值。
  • 使用try-catch完成的

代码如下:

let arr = [{
  id: '001',
  name: '张三1'
}, {
  id: '002',
  name: '张三2'
}, {
  id: '003',
  name: '张三2'
}];

// 使用forEach跳出整个循环,使用rty-catch
function useForeach(Arr) {
  let obj = {}
  try {
    Arr.forEach(function(item) {
      if (item.id == '002') {
        // 找到目标项,赋值。然后抛出异常
        obj = item
        throw new Error('return false')
      }
    });
  } catch (e) {
    // 返回id===002的这一项的数据
    return obj
  }
}
console.log(useForeach(arr))

3.forEach 与for循环的区别 【面试题】

1==> for可以用continue跳过当前循环中的一个迭代,forEach 用continue会报错。但是可以使用return来跳出当前的循环
2==> for可以使用break来跳出整个循环,forEach正常情况无法跳出整个循环。
如果面试官问:如果非要跳出forEach中的循环,可以抛出一个异常来处理

到此这篇关于js中forEach的用法之forEach与for之间的区别的文章就介绍到这了,更多相关js forEach与fo的区别内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

js中forEach的用法之forEach与for之间的区别

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

js中forEach怎么使用及forEach与for的区别是什么

本篇内容介绍了“js中forEach怎么使用及forEach与for的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、定义和用法
2023-06-29

Java中for与foreach的区别是什么

本篇内容主要讲解“Java中for与foreach的区别是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中for与foreach的区别是什么”吧!(1)遍历元素首先,我们一一段代码为
2023-06-30

jsp中页面之间的跳转forward与sendRedirect的区别

在JSP中,forward和sendRedirect都用于页面之间的跳转,但它们有一些不同之处。1. forward是服务器端跳转,sendRedirect是客户端跳转。当使用forward时,服务器会直接将控制权转移到目标页面,而客户端不
2023-08-14

java中创建文件的方法之间的区别

区别:mkdir和mkdirs:mkdir只能用来创建文件夹,且只能创建一级目录;mkdirs同样只能用来创建文件夹,可创建多级目录 ,如果上级不存在,就会自动创建。createNewFile:只能用来创建文件,且只能在已存在的目录下创建文件。一般情况下配合使
java中创建文件的方法之间的区别
2022-01-02

Linux开发中sudo与su之间的区别是什么

Linux开发中sudo与su之间的区别是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。在Linux开发中我们一般都是以普通用户就行工作,有时会因为个别原因
2023-06-28

Spring中@Service注解的作用与@Controller和@RestController之间区别是什么

本篇内容介绍了“Spring中@Service注解的作用与@Controller和@RestController之间区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!
2023-07-05

Shell编程中while与for的区别及用法详解

在shell编程中经常用到循环,常用的循环有for和while循环两种。while循环默认以行读取文件,而for循环以空格读取文件切分文件,本篇就结合现网的一些使用示例说说二者的用法和区别。 一、常用语法 1、for循环 for循环常用的语
2022-06-04

JS中call(),apply(),bind()函数的区别与用法详解

这篇文章主要介绍了JS中call(),apply(),bind()函数的高级用法详解,需要的朋友可以参考下
2022-12-10

Linux系统关机命令之间的区别及用法详解

Linux系统关机命令有哪些呢?良许教程网为您解答!熟悉linux的朋友应该知道我们在linux系统中常用到的关机命令有:shutdown、halt、poweroff、init;重启命令有:reboot。下面本文就主要介绍一些常用的关机命令
2022-06-03

Java中的for-each循环与迭代器遍历有何区别?(Java中的for-each循环与迭代器遍历方式之间有哪些不同?)

Java中的for-each循环和迭代器遍历是遍历集合的两种方式。for-each循环简洁易用,但缺乏灵活性且不能并发遍历。迭代器遍历提供了更多的控制和灵活性,但性能可能较低,需要更多的代码。选择哪种方法取决于具体需求:需要快速、简洁的遍历且不需要修改/删除元素:for-each循环需要修改/删除元素、反向遍历或并发遍历:迭代器遍历
Java中的for-each循环与迭代器遍历有何区别?(Java中的for-each循环与迭代器遍历方式之间有哪些不同?)
2024-04-02

详解CSS伪类和伪元素的用法以及它们之间的区别

CSS伪类和伪元素的区别及用法详解伪类和伪元素是在CSS中经常使用的概念,它们可以帮助我们选择和样式化HTML中的特定元素。虽然它们的名字相似,但它们有不同的用法和功能。在本文中,我们将详细解释CSS伪类和伪元素的区别,并给出具体的代码示例
详解CSS伪类和伪元素的用法以及它们之间的区别
2023-12-23

编程热搜

目录