JavaScript中 forEach map 方法 无法跳出循环问题及解决方案
Posted 明天也要努力
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript中 forEach map 方法 无法跳出循环问题及解决方案相关的知识,希望对你有一定的参考价值。
1. 问题
1.1 forEach() 方法
使用 return 不退出循环
const arr = [1,2,3,4,5];
const test = 3;
arr.forEach((item) => {
if(item == test){
return item
}
console.log(item);
})
使用 break 报错
const arr = [1,2,3,4,5];
const test = 3;
arr.forEach((item) => {
if(item == test){
break
}
console.log(item);
})
1.2 map() 方法
使用 return 不退出循环
const arr = [1,2,3,4,5];
const test = 3;
arr.map((item) => {
if(item == test){
return
}
console.log(item);
})
使用 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中 forEach map 方法 无法跳出循环问题及解决方案的主要内容,如果未能解决你的问题,请参考以下文章
如何形象地解释 JavaScript 中 map,foreach,reduce 间的区别
JavaScript中的数组遍历forEach()与map()方法以及兼容写法