JavaScript中break、continue和return的區別


break

function myBreak() {
    for(var i = 0; i < 5; i++) {
        if(i == 3) {
            break;
        }
    console.log(i);
    }
}
myBreak();              

輸出:

0
1
2

break: 直接跳出 當前 的循環,從當前循環外面開始執行,忽略循環體中任何其他語句和循環條件測試。它只能跳出一層循環,如果你的循環是嵌套循環,那么你需要按照你嵌套的層次,逐步使用break來跳出。

continue

function myContinue() {
    for(var i = 0; i < 5; i++) {
        if(i == 3) {
            continue;
        }
    console.log(i);
    }
}
myContinue();        

輸出:

0
1
2
4

continue: 終止當前的一次循環過程,其 不 跳出循環,而是繼續往下判斷循環條件執行語句。

只能結束循環中的一次過程,但不能終止循環繼續進行。

return

function myReturn() {
   for(var i = 0; i < 5; i++) {
        if(i == 3) {
            return i;
        }
    console.log(i);
    }
}
var s = myReturn();
console.log("s: " + s);    

輸出:

0
1
2
s: 3

return: 從當前的方法中退出,返回到該調用的方法的語句處,繼續執行。

再放一道continue和break的題目

for (var i = 0; i < 10; i++) {
    if (i < 5) {
        i++;
        continue;//=>結束本輪循環(循環體中continue后面代碼將不再執行),繼續執行下一輪循環
    }
    if (i > 7) {
        i += 2;
        break;//=>強制結束整個循環,不做任何的處理
    }
    i += 1;
}

總結

1、return語句的作用

(1) return 從當前的方法中退出,返回到該調用的方法的語句處,繼續執行

(2) return 返回一個值給調用該方法的語句,返回值的數據類型必須與方法的聲明中的返回值的類型一致,可以使用強制類型轉換來是數據類型一致

(3) return 當方法說明中用void聲明返回類型為空時,應使用這種格式,不返回任何值。

2、break語句的作用

(1) 只能在循環體內和switch語句體內使用break語句。

(2) 當break出現在循環體中的switch語句體內時,其作用只是跳出該switch語句體。

(3) 當break出現在循環體中,但並不在switch語句體內時,則在執行break后,跳出本層循環體。

(4) 在循環結構中,應用break語句使流程跳出本層循環體,從而提前結束本層循環

3、continue語句作用

(1) continue語句的一般形式為:continue;

(2) 其作用是結束本次循環,即跳過本次循環體中余下尚未執行的語句,接着再一次進行循環的條件判定。

(3) 注意:執行continue語句並沒有使整個循環終止。在while和do-while循環中,continue語句使得流程直接跳到循環控制條件的測試部分 ,然后決定循環是否繼續進行。

(4) 在for 循環中,遇到continue后,跳過循環體中余下的語句,而去對for語句中的“表達式3”求值,然后進行“表達式2”的條件測試,

最后根據“表達式2”的值來決定for循環是否執行。在循環體內,不論continue是作為何種語句中的語句成分,都將按上述功能執行,這點與break有所不同


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM