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

勤奋不是嘴上说说而已,而是实际的行动,在勤奋的苦度中持之以恒,永不退却。业精于勤,荒于嬉;行成于思,毁于随。在人生的仕途上,我们毫不迟疑地选择勤奋,她是几乎于世界上一切成就的催产婆。只要我们拥着勤奋去思考,拥着勤奋的手去耕耘,用抱勤奋的心去对待工作,浪迹红尘而坚韧不拔,那么,我们的生命就会绽放火花,让人生的时光更加的闪亮而精彩。

导读:本篇文章讲解 JavaScript中 forEach map 方法 无法跳出循环问题及解决方案,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

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);
})

在这里插入图片描述
问题2:使用 break 报错

const arr = [1,2,3,4,5];
const test = 3;

arr.forEach((item) => {
  if(item == test){
	break
  }
  console.log(item);
})

在这里插入图片描述

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);
})

在这里插入图片描述
问题2:使用 break 报错

const arr = [1,2,3,4,5];
const test = 3;

arr.map((item) => {
  if(item == test){
	break
  }
  console.log(item);
})

在这里插入图片描述

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())

在这里插入图片描述

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);
})

在这里插入图片描述

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;
  } 
})

在这里插入图片描述

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/141346.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!