javascript 跳出(终止)forEach循环

javascript 跳出(终止)forEach循环

CreateTime--2018年4月23日17:58:12

Author:Marydon

报错信息:javascript

解决方案:html

  javascript 跳出forEach循环,使用的是return false,而不是break,js里面没有break关键字java

1.错误用法一jquery

  原生态的forEach()方法体中,结束循环不能使用break。数组

var array = ["first","second","third","fourth"];
        
// 直接就报错了
array.forEach(function(item,index){
    if (item == "third") {
        break;
    }
    alert(item);
});

2.错误用法二 函数

  从网上说使用return false,然并卵spa

var array = ["first","second","third","fourth"];
        
// 会遍历数组全部元素,只是执行到第3次师,return false下面的代码再也不执行而已
array.forEach(function(item,index){
    if (item == "third") {
        return false;
    }
    alert(item);// first,second
});

  说明:code

  forEach()没法在全部元素都传递给调用的函数以前终止遍历,htm

  return false 在这里起的做用是:只是终止本次继续执行,而不是终止for循环。blog

3.正确作法

  由于forEach()没法经过正常流程终止,因此能够经过抛出异常的方式实现终止  

try {
    var array = ["first","second","third","fourth"];
    
    // 执行到第3次,结束循环
    array.forEach(function(item,index){
        if (item == "third") {
            throw new Error("EndIterative");
        }
        alert(item);// first,sencond
    });
} catch(e) {
    if(e.message!="EndIterative") throw e;
};
// 下面的代码不影响继续执行
alert(10);

4.结束for循环,使用break。

// 终止for循环,使用break
for (var i=0; i < 3; i++) {
    if (1==i) {
        break;
    }
    alert(i);//0
}