JavaScript中 forEach map 方法 无法跳出循环问题及解决方案

简介: JavaScript中 forEach map 方法 无法跳出循环问题及解决方案

1.1 forEach() 方法

定义和用法: forEach() 方法按顺序为数组中的每个元素调用一次函数。

注意: 对于没有值的数组元素,不执行forEach() 方法。

语法:

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

问题1:使用 return 不退出循环

const arr = [1,2,3,4,5];
const test = 3;
arr.forEach((item) => {
  if(item == test){
  return item
  }
  console.log(item);
})

2020062310470442.png

问题2:使用 break 报错

const arr = [1,2,3,4,5];
const test = 3;
arr.forEach((item) => {
  if(item == test){
  break
  }
  console.log(item);
})

2020062310470442.png

1.2 map() 方法

定义和用法:

map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

map() 方法按照原始数组元素顺序依次处理元素。

注意: map() 不会对空数组进行检测,不会改变原始数组。

语法:

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

问题1:使用 return 不退出循环

const arr = [1,2,3,4,5];
const test = 3;
arr.map((item) => {
  if(item == test){
  return 
  }
  console.log(item);
})

2020062310470442.png

问题2:使用 break 报错

const arr = [1,2,3,4,5];
const test = 3;
arr.map((item) => {
  if(item == test){
  break
  }
  console.log(item);
})

2020062310470442.png

2. 解决方案

2.1 使用 for 循环

注意: return 只能出现在函数体中,也就是 function 中 或 {} 中 。直接写在循环中会报错 Uncaught SyntaxError: Illegal return statement。

const arr = [1,2,3,4,5];
const count = 3;
function test(){
  for(let i = 0; i < arr.length; i++){
  if(arr[i] == count){        
     return arr[i]
  }
  } 
}
console.log(test())

2020062310470442.png

2.2 使用 some () 方法,当内部 return true 时跳出整个循环

const arr = [1,2,3,4,5];
const test = 3;
arr.some((item) => {
  if(item == test){
  return item;     // 返回值为true,并跳出循环
  }
  console.log(item);
})

2020062310470442.png

2.3 使用 every() 方法 : 当内部 return false 时跳出整个循环(需要写 return true )

const arr = [1,2,3,4,5];
const test = 3;
arr.every((item) => {
  if(item == test){
  return false;    
  }else{
    console.log(item);
    return true;
  } 
})

2020062310470442.png

传送门:JavaScript中 数组迭代(遍历)的几种方法

相关文章
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法详解
本指南详细介绍在Linux系统中安装和管理Node.js的步骤。首先检查现有环境,包括查看当前版本和清除旧版本;接着通过NodeSource仓库安装最新版Node.js并验证安装结果。推荐使用nvm(Node Version Manager)进行多版本管理,便于切换和设置默认版本。同时,提供常见问题解决方法,如权限错误处理和全局模块迁移方案,以及版本回滚操作,确保用户能够灵活应对不同需求。
1483 0
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法
Debian 11更新Node.js主要就是这三种方式,无论你是初涉其中的新手还是找寻挑战的专家,总有一种方式能满足你的需求。现在,你已经是这个
1494 80
|
JavaScript 前端开发 Java
js 垃圾回收机制的方法
JS回收机制方法讲解
|
移动开发 运维 供应链
通过array.some()实现权限检查、表单验证、库存管理、内容审查和数据处理;js数组元素检查的方法,some()的使用详解,array.some与array.every的区别(附实际应用代码)
array.some()可以用来权限检查、表单验证、库存管理、内容审查和数据处理等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
12月前
|
安全 Java 数据库连接
让我们讲解一下 Map 集合遍历的方式
我是小假 期待与你的下一次相遇 ~
404 43
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19

热门文章

最新文章