JavaScript 提供了完整的控制机制来处理循环和开关语句。可能会出现需要在没有到达循环底部的情况下提前退出循环的情况。也可能出现想要跳过代码块的一部分并开始下一次循环迭代的情况。
为了处理所有这些情况,JavaScript 提供了 break 和 continue 语句。这些语句分别用于立即退出任何循环或开始下一次循环迭代。此外,JavaScript 允许开发者使用标签来命名循环。
我们在下面的表格中解释了可以用来控制循环的关键字。
| 关键字 | 解释 | 
| break | break关键字用于完全退出循环。 | 
| continue | continue关键字用于跳过当前循环迭代。 | 
| 标签 | 标签不是关键字,但你可以使用任何标识符后面跟一个冒号 ( :) 来给循环加上标签。之后,你可以使用标签配合break和continue关键字来针对特定的循环。 | 
在后面的章节中,我们将详细介绍 break、continue 和标签语句。
break 语句
JavaScript break 语句,最初是在介绍 switch 语句时提到的,用于提前退出循环,跳出封闭的大括号。

示例
下面的例子展示了如何在 while 循环中使用 break 语句。注意当 x 达到 5 时,循环提前结束。
<html>
<body>     
   <div id="output"></div>  
   <script>
      const coutput = document.getElementById("output");
      let x = 1;
      coutput.innerHTML = "进入循环<br>";
      while (x < 20) {
         if (x == 5) {
            break;   
         }
         x = x + 1;
         coutput.innerHTML += x + "<br>";
      }         
      coutput.innerHTML += "退出循环!<br>";
   </script>
   <p>设置变量为不同的值然后再次尝试...</p>
</body>
</html>
输出:
进入循环
2
3
4
5
退出循环!
设置变量为不同的值然后再次尝试...
continue 语句
JavaScript continue 语句告诉解释器立即开始下一次循环迭代并跳过剩余的代码块。当遇到 continue 语句时,程序流立即移动到循环检查表达式;如果条件仍然为真,则开始下一次迭代,否则控制权退出循环。
示例
此示例展示了如何在 while 循环中使用 continue 语句。注意当变量 x 的值达到 5 时,continue 语句用于跳过打印操作。
<html>
<body>     
   <div id="output"></div>  
   <script>
      const coutput = document.getElementById("output");
      let x = 1;
      coutput.innerHTML = "进入循环<br>";
      while (x < 10) {
         x = x + 1;
         if (x == 5) {
            continue; 
         }
         coutput.innerHTML += x + "<br>";
      }         
      coutput.innerHTML += "退出循环!<br>";
   </script>
   <p>设置变量为不同的值然后再次尝试...</p>
</body>
</html>
输出:
进入循环
2
3
4
6
7
8
9
10
退出循环!
设置变量为不同的值然后再次尝试...
使用标签来控制流程
从 JavaScript 1.2 开始,可以使用标签与 break 和 continue 一起更精确地控制流程。标签只是一个标识符后面跟着一个冒号 (:),它可以应用到一个语句或一段代码块上。我们将通过两个不同的例子来了解如何使用标签与 break 和 continue 一起。
continue 或 break 语句与其标签名之间不允许有换行。此外,标签名与相关的循环之间也不应该有任何其他语句。
尝试以下两个例子以更好地理解标签。
示例 1
下面的例子展示了如何实现带 break 语句的标签。
在下面的例子中,我们给循环加上了 outerloop 和 innerloop 标签。
我们在嵌套循环中使用了带标签的 break 语句。在输出中,你可以看到它从内部循环中断了外部循环。
<html>
<body>     
   <div id="output"></div>  
   <script>
      const coutput = document.getElementById("output");
      coutput.innerHTML = "进入循环!<br>";
      outerloop:        
      for (let i = 0; i < 5; i++) {
         coutput.innerHTML += "外层循环: " + i + "<br>";
         innerloop:
         for (let j = 0; j < 5; j++) {
            if (j > 3) break;           
            if (i == 2) break innerloop;  
            if (i == 4) break outerloop;  
            coutput.innerHTML += "内层循环: " + j + " <br>";
         }
      }        
      coutput.innerHTML += "退出循环!<br>";
   </script>
</body>
</html>
输出:
进入循环!
外层循环: 0
内层循环: 0
内层循环: 1
内层循环: 2
内层循环: 3
外层循环: 1
内层循环: 0
内层循环: 1
内层循环: 2
内层循环: 3
外层循环: 2
外层循环: 3
内层循环: 0
内层循环: 1
内层循环: 2
内层循环: 3
外层循环: 4
退出循环!
示例 2
在下面的代码中,我们在嵌套循环中使用了带标签的 continue 语句来跳过当前外层循环的迭代。每当 q 的值变成 3 时,它就会跳过当前迭代的剩余代码并开始新的迭代。
<html>
<head>
   <title>JavaScript - 标签语句</title>
</head>
<body>
   <p id="output"></p>
   <script>
      let coutput = document.getElementById("output");
      coutput.innerHTML += "进入循环!<br>";
      outerloop:     
      for (let p = 0; p < 3; p++) {
         coutput.innerHTML += "外层循环: " + p + "<br>";
         for (let q = 0; q < 5; q++) {
            if (q == 3) {
               continue outerloop;
            }
            coutput.innerHTML += "内层循环: " + q + "<br>";
         }
      }
      coutput.innerHTML += "退出循环!<br>";
   </script>
</body>
</html>
输出:
进入循环!
外层循环: 0
内层循环: 0
内层循环: 1
内层循环: 2
外层循环: 1
内层循环: 0
内层循环: 1
内层循环: 2
外层循环: 2
内层循环: 0
内层循环: 1
内层循环: 2
退出循环!