详谈for循环里面的break和continue语句

break语句

哇,我已经找到我要的答案了,我不需要进行更多的循环了!

比如,寻找第一个能被5整除的数:

for循环中,如果遇见了break语句,这个for循环就会立即终止,不在进行其他的迭代了。

rush:js;"> for(var i = 1 ; i <= 100; i++){

   console.log(i);

   if(i == 5){

     break; //找到了一个,就立即终止循环

  }

}

break语句只能跳出当前所在的最内层循环:

rush:js;"> //break只中断了最内层循环,外层循环还在继续

for(var i = 1 ; i <= 10 ; i++){

   for(var j = 1 ; j <= 10 ; j++){

     console.log(i,j);

    if(j == 5){

     break;

     }

  }

}

如果你这个break就是想终止所有的循环,那么JS中允许你给循环语句加label

rush:js;"> //break只能终止内层循环,但是我们就是想要终止外层循环

//就要给外层循环加label:

waiceng : for(var i = 1 ; i <= 10 ; i++){

   for(var j = 1 ; j <= 10 ; j++){

     console.log(i,j);

    if(j == 5){

     break waiceng; //break label的语法

     }

   }

}

continue语句

呃,这个答案不是我想要的,赶紧试试下一个数字吧!

遇见continue语句,for会立即终止执行后面的语句,然后进入下一次迭代了。

rush:js;"> for(var i = 1 ; i <= 100 ; i++){

   if(i == 5){

     continue; //当i为5的时候,立即终止执行后面的console语句,直接i为6了。

  }

   console.log(i);

}

同样的,continue只能终端当前最内层的for,外层for要加label。

break和continue的目的,就是优化算法的。

寻找质数的方法

rush:js;">

以上这篇详谈for循环里面的break和continue语句就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...