JS 的 Array.forEach 方法如何跳出循环

2024-04-10 03:28

本文主要是介绍JS 的 Array.forEach 方法如何跳出循环,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. for 结束循环

众所周知,在 for 循环语句中,遇到 break 会结束循环。但是如何在数组方法 array.forEach() 中如何结束循环呢 ?

 
  1. const arr = ['html', 'css', 'js', 'vue', 'php']
  2. for (let i = 0; i < arr.length; i++) {
  3. // 第一次循环输出: html
  4. // 第二次循环输出: css
  5. // 第三次循环输出: js
  6. console.log(arr[i]);
  7. // 第三次循环时,条件成立,停止循环
  8. if (arr[i] == 'js') break;
  9. }
2. forEach 结束循环

forEach 本身无法跳出循环,但是我们可以通过系统的一些强制性方法使其结束循环,如下所示:

 
  1. try {
  2. arr.forEach(item => {
  3. if (item == 'js') throw new Error('结束循环');
  4. })
  5. } catch (error) {
  6. console.log(error.message);
  7. }

上面写法存在问题,当循环中有一些其他异常时,理应抛出异常,而不是认为是结束循环的异常。改进后:

 
  1. try {
  2. arr.forEach(item => {
  3. console.log(item);
  4. if (item == 'css') item + a; // a is not defined
  5. if (item == 'js') throw new Error('结束循环');
  6. })
  7. } catch (error) {
  8. if (error.message !== '结束循环') {
  9. throw error;
  10. }
  11. }
3. 利用高阶函数进行循环

Array.some() 方法用于检测数组中的元素是否满足指定条件,有一个满足就停止循环,然后返回 true

也就是闭包函数的返回值为 true 时,停止循环。利用这一特性,可以控制循环中何时返回 true,进行控制何时结束循环

 
  1. const arr = ['html', 'css', 'js', 'vue', 'php']
  2. arr.some(item => {
  3. // 循环三次,依次输出 html css js
  4. console.log(item);
  5. if (item == 'js') {
  6. return true
  7. }
  8. })

Array.every() 方法用于检测数组中的所有元素是否满足指定条件,有一个不满足就停止循环,然后返回 false

同理,通过控制返回值,一样能控制何时结束循环

 
  1. const arr = ['html', 'css', 'js', 'vue', 'php']
  2. arr.every(item => {
  3. // 循环三次,依次输出 html css js
  4. console.log(item);
  5. if (item == 'js') {
  6. return false
  7. }
  8. return true
  9. })
4. 开发中到底应该使用哪种方式

开发中,遇到需要循环一个数组,并且当循环到某一个元素时要跳出循环,建议书写方式如下所示:

 
  1. const arr = ['html', 'css', 'js', 'vue', 'php']
  2. // 推荐方式一
  3. for (let i = 0; i < arr.length; i++) {
  4. if (arr[i] == 'js') {
  5. break;
  6. }
  7. }
  8. // 推荐方式二
  9. arr.some(item => {
  10. if (item == 'js') {
  11. return true
  12. }
  13. })

这篇关于JS 的 Array.forEach 方法如何跳出循环的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/889954

相关文章

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

c++中std::placeholders的使用方法

《c++中std::placeholders的使用方法》std::placeholders是C++标准库中的一个工具,用于在函数对象绑定时创建占位符,本文就来详细的介绍一下,具有一定的参考价值,感兴... 目录1. 基本概念2. 使用场景3. 示例示例 1:部分参数绑定示例 2:参数重排序4. 注意事项5.

Windows设置nginx启动端口的方法

《Windows设置nginx启动端口的方法》在服务器配置与开发过程中,nginx作为一款高效的HTTP和反向代理服务器,被广泛应用,而在Windows系统中,合理设置nginx的启动端口,是确保其正... 目录一、为什么要设置 nginx 启动端口二、设置步骤三、常见问题及解决一、为什么要设置 nginx

树莓派启动python的实现方法

《树莓派启动python的实现方法》本文主要介绍了树莓派启动python的实现方法,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、RASPBerry系统设置二、使用sandroidsh连接上开发板Raspberry Pi三、运

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Python实现视频转换为音频的方法详解

《Python实现视频转换为音频的方法详解》这篇文章主要为大家详细Python如何将视频转换为音频并将音频文件保存到特定文件夹下,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5. 注意事项