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
}

 

相關文章
相關標籤/搜索