经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
js for终止循环 跳出多层循环
来源:jb51  时间:2018/10/8 8:44:12  对本文有异议

今天w3xue小编写带代码的时候遇到一段代码,需要终止运行for,通过遍历json数据实现判断

  1. <script>
  2. var Tid="55555";
  3. var jb51cp = [
  4. {id:66666,Cpurl:"https://baidu.com"},
  5. {id:55555,Cpurl:"https://www.jb51.net"}
  6. ];
  7. for(var i = 0; i < jb51cp.length; i++){
  8. if(jb51cp[i].id==Tid){
  9. var thevalue=jb51cp[i].Cpurl;
  10. break;
  11. }
  12. }
  13. alert(thevalue);
  14. </script>

通过上面的代码,完美解决了我的需求,但感觉性能不高,建议用switch函数,json方便批量输出,通过for判断会降低性能。注意查看break的地方。

示例代码

  1. var a = [1,2,3,4,5,6,7,8]; // 8个数
  2. var b = [11,12,13,14,15,3,16,17]; //8个数
  3.  
  4. testFor();
  5. console.log('555')
  6.  
  7. function testFor() {
  8. for(var k=0;k<a.length;k++){
  9. console.log('444');
  10. for(var i=0;i<a.length;i++){
  11. for(var j=0;j<b.length;j++){
  12. if( a[i]==b[j] ){
  13. return false;
  14. }
  15. console.log('111');
  16. }
  17. console.log('2222');
  18. }
  19. console.log('333');
  20. }
  21. }
  22.  
  23.  
  24. 输出:
  25. // 1次444
  26. // 8次111
  27. // 1次222
  28. // 8次111
  29. // 1次222
  30. // 5次111
  31. // 1次555

可见 return 会直接跳出多层循环,返回调用的方法外部
原因: js里for是没有局部作用域的概念,方法才能一个局部作用域
return将会跳出当前局部作用继续执行下面的方法

注意:

1.这里for循环如果直接放在全局作用域下执行而不被一个方法包裹,
将直接导致写在for后的代码永远不会被执行;

2.如遇到逻辑特别复杂多层循环的时候,会遇到一些迭代器之类的方法,
这种迭代器实现的不同,会出现另一种情况,即不会跳出任何循环,
循环仍然继续,只是当前循环if后的代码不会被执行一次,下一次循环开始时,
仍然会执行if后的代码

如:

var cc = 'xx';

Object.keys(o).forEach(function(key) {
var val = o[key];
if(cc == key){
return false;
}
console.log(key);
});

此外还有

break;
continue;

语句
break 语句跳出循环后,会继续执行该循环之后的代码 (退出循环)
continue continue 语句中断循环中的迭代,如果出现了指定的条件,然后继续循环中的下一个迭代。(跳过当前迭代,进入下次迭代)
这两个语句可以指定label从而可以退出特定的循环

  1. bbq:
  2. for(var j=0;j<a.length;j++){
  3. ccc:
  4. for(var i =0;i<a.length;i++){
  5. if( i==5 ){
  6. break bbq; //直接跳出bbq外层循环
  7. }
  8. }
  9. }
  10.  
  11.  
  12. 或者:
  13. function testFor() {
  14. bbq:
  15. for(var k=0;k<a.length;k++){
  16. console.log('444');
  17. ccc:
  18. for(var i=0;i<a.length;i++){
  19. ddd:
  20. for(var j=0;j<b.length;j++){
  21. if(j == 2){
  22. break;
  23. }
  24. console.log('j '+j);
  25. }
  26. console.log('i '+i);
  27. }
  28. console.log('k '+k);
  29. }
  30. }

// 只会每次循环j==2时退出ddd循环然后外面的循环都会继续循环

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号