背景
这个问题平时工作中基本不会遇到,通常是面试时,有的面试官喜欢问这个,所以有了探讨的意义。 首先我们来看看 for 循环是怎么处理跳出的。
for循环
JavaScript中,for循环可以使用 break
和 continue
来跳出:
- continue:跳出本次循环
- break:结束循环
js
for (let i = 0; i < 10; i++) {
if (i === 1) {
// 跳出本次循环,不会打印1
continue
}
if (i === 3) {
// 结束循环,不会打印3和之后的数字
break
}
// 输出0 2
console.log(i)
}
forEach循环
了解了 for 循环跳出之后,forEach 如何跳出呢?
js
const numbers = [1, 2, 3, 4, 5]
numbers.forEach(number => {
if (number === 2) {
// 跳出整个循环
break // SyntaxError: Illegal break statement
}
console.log(number)
})
可以看到,直接使用break,会报非法中断语句错误 再试试 continue
:
js
numbers.forEach(number => {
if (number === 2) {
// 跳出当前循环
continue // SyntaxError: Illegal continue statement: no surrounding iteration statement
}
console.log(number)
})
可以看到同样报错,continue不能在非循环语句中,原因是forEach的参数是一个回调函数,并不是循环语句,所以无法执行continue语句 具体可以参考:SyntaxError: continue must be inside loop - JavaScript | MDN 里面也提到了解决方法,使用 return
退出当前循环,以及使用 for of
代替forEach
js
numbers.forEach(number => {
if (number === 2) {
// 跳出当前循环
return
}
console.log(number) // 1 3 4 5
}
js
for (const number of numbers) {
if (number === 2) {
continue
}
console.log(number) // 1 3 4 5
}
但是就想使用 forEach
来跳出循环应该如何操作呢,上面文档中没有提到,但可以使用 try catch
来实现:
js
try {
numbers.forEach(number => {
if (number === 2) {
throw new Error()
}
console.log(number) // 1
})
} catch (error) {
console.log('捕获到错误')
}
另辟蹊径
除了上面的用法,前几天看有个文章的评论的时候,发现一个方法,大家也可以尝试一下。
js
var list = [1, 2, 3, 4, 5]
list.forEach((v, index) => {
if (v == 3) {
list = list.splice(0, index)
}
console.log(index)
})
在想要跳出循环的时候,将原数组的数量减少,这样就直接跳出了数组,可以说是非常巧妙了😂,大家也可以试试。
综上,使用 forEach 时,使用 return
跳出当前循环,使用 try catch
跳出整个循环,同时也可以试试上面的另类方法。