标签:跳出 arr console JavaScript num item 循环 foreach forEach
通常,在 for
循环中跳出循环可以用 break
或者 continue
来跳出循环。
break
:跳出循环;
continue
:跳过当次循环。
而有时候需要在 foreach
中跳出循环,该怎么做呢?
forEach() 方法用于调用数组的每个元素,并将元素传递给回调函数。对于空数组不会执行回调函数。
回调函数的参数 :
function(currentValue, index, arr)
currentValue 必需。当前元素
index 可选。当前元素的索引值
arr 可选。当前元素所属的数组对象
在 forEach 中使用return:
let arr = [1,2,3,4,5,6,7,8,9];
let num = 6
arr.forEach((item)=>{
if(item == num) {
return;
}
console.log('item',item);
})
console.log(123)
运行结果:
可以看到,forEach
中使用 return
语句的作用只能跳出当前循环(实现了continue
的效果),并不能跳出整个循环,没达到期待的效果,满足条件后还继续执行了循环。
在 forEach 中使用break:
let arr = [1,2,3,4,5,6,7,8,9];
let num = 6
arr.forEach((item)=>{
if(item == num) {
break;
}
console.log('item',item);
})
console.log(123)
运行结果:
直接报错了,后面的代码也没执行。
在 forEach 中使用continue:
let arr = [1,2,3,4,5,6,7,8,9];
let num = 6
arr.forEach((item)=>{
if(item == num) {
continue;
}
console.log('item',item);
})
console.log(123)
运行结果:
和 break 一样,直接报错了,后面的代码也没执行。
上面的例子可以看到,foreach
不能使用break
和continue
这两个关键字。
因为 forEach
本身无法跳出循环,必须遍历所有的数据才能结束,它传入的是一个回调函数,因此形成了一个作用域,它内部所定义的变量不会像for循环一样污染全局变量。
解决方法
forEach方法跳出循环 —— 通过 try catch
抛出异常的方式跳出循环
let arr = [1,2,3,4,5,6,7,8,9];
let num = 6
try {
arr.forEach((item, i)=> {
console.log('item',item)
if (item === num) {
throw new Error('LoopInterrupt'); //满足条件,跳出循环
}
})
} catch (e) {
if (e.message !== "LoopInterrupt") throw e
}
console.log(123)
运行效果:
标签:跳出,arr,console,JavaScript,num,item,循环,foreach,forEach 来源: https://blog.csdn.net/HH18700418030/article/details/121165171
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。