break
语句能够用于跳出循环,能够用在 for 循环、while 循环、switch 循环中。当咱们在一个循环中使用了break
语句,则会中断循环,可是仍会继续执行循环以后的代码哟。html
例以下面代码实现了当循环条件小于5时,循环中断:浏览器
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>JS_侠课岛(9xkd.com)</title> </head> <body> <script> var n = 5; for(i = 0; i < 10; i++){ console.log(i); // 在判断以前就输出 if(i > n){ console.log("循环到数字5时,中断循环"); break; } } </script> </body> </html>
此时咱们在浏览器中打开页面,控制台会输出:
上述代码中,咱们在 for
循环中,输出了变量 i
的值,正常的循环会一直输出0、一、二、三、四、五、六、七、八、9
。可是由于咱们在循环里面添加了一个 if
条件语句,当条件为 true 的时候,会执行 if
下面的代码块。也就是说当变量 i
大于 5 时,程序中会执行 break
语句,此时 for
循环会终止,无论后面还有多少次循环都不会再执行。spa
那最后一个输出是5仍是6仍是7呢?这里可能会有同窗弄不清楚,那咱们来说一下。3d
for
循环中的条件表达式 i < 10
,因此会执行循环的代码块console.log(i);
,会输出 5。而后执行到 if
条件语句时,条件为 i
是否大于5,那么 5 确定是不会大于 5,条件不知足,不会执行 if
的代码块,进入下一次循环。if
条件语句,此时 6 大于 5,说明知足 if
语句的条件,执行代码块,执行 break
,跳出循环,循环再也不继续。注意一下,若是在循环体的后面还有其余的代码,在跳出循环以后,会继续执行循环后面的代码。也就是说 break
只能影响到在循环里面的代码,外面的代码依然是照旧执行。code
例以下面这段代码,跳出循环体后,还会继续执行后面的输出语句:htm
<script> var n = 5; for(i = 0; i < 10; i++){ console.log(i); if(i > n){ console.log("循环到数字5时,中断循环"); break; } } console.log("循环中断后,继续执行for循环以后的代码"); // 跳出循环后,继续执行后面的语句 </script>
在浏览器中打开:blog
continue
语句用于在发生指定的条件时,中断循环中的一个迭代,而后继续循环中的下一个迭代。ip
与 break
语句不一样的是, break
会执行跳出整个循环,而 continue
只是跳出本次循环,继续下一次循环。也就是说假如一共有10次循环,在第 5 次循环时使用 break
,后面的循环不会再执行。可是若是在第 5 次循环的时候执行 continue
,只有第 5 次循环不会执行,但会继续执行第6次、7次...等循环。utf-8
例以下列代码中,当 i
的值为 5 时,会跳出本次循环,继续下次循环:rem
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>JS_侠课岛(9xkd.com)</title> </head> <body> <div> <p id="num"></p> </div> <script> var n = 5; for(i = 0; i < 10; i++){ if(i == n){ continue; } console.log(i); // 执行if语句以后输出 } </script> </body> </html>
在浏览器中打开:
在循环体内,当变量 i
的值知足 if
条件 i == n
时,会跳出本次循环,而后继续下一次循环,因此循环结果中不会输出5,可是输出了 六、七、八、9
。
1.请使用循环语句输出1到100中,除了42之外全部能被 7 整数的整数?
2.请说出下列代码的输出结果:
for(var i = 0; i < 10; i++){ if( i == 3){ continue; } console.log(i); if( i > 7){ break; } }