js for终止循环 跳出多层循环

本文探讨了JavaScript中使用for循环遍历JSON数据并进行条件判断的效率问题,对比了不同循环控制语句如break、return及迭代器的性能表现,并提出了在复杂逻辑下优化循环性能的策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

<script>
var Tid="55555";
var jb51cp = [
{id:66666,Cpurl:"https://baidu.com"},
{id:55555,Cpurl:"https://www.jb51.net"}
];
  
  
for(var i = 0; i < jb51cp.length; i++){
    if(jb51cp[i].id==Tid){
    var thevalue=jb51cp[i].Cpurl;
    break;
        }
}
alert(thevalue);
</script>

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

示例代码

var a = [1,2,3,4,5,6,7,8]; // 8个数
var b = [11,12,13,14,15,3,16,17]; //8个数
 
testFor();
console.log('555')
 
function testFor() {
 for(var k=0;k<a.length;k++){
 console.log('444');
 for(var i=0;i<a.length;i++){
  for(var j=0;j<b.length;j++){
  if( a[i]==b[j] ){
   return false;
  }
  console.log('111');
  }
  console.log('2222');
 }
 console.log('333');
 }
}
 
 
输出:
// 1次444
// 8次111
// 1次222
// 8次111
// 1次222
// 5次111
// 1次555
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

可见 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从而可以退出特定的循环 如

bbq:
for(var j=0;j<a.length;j++){
 ccc:
 for(var i =0;i<a.length;i++){
  if( i==5 ){
   break bbq; //直接跳出bbq外层循环
  }
 }
}
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

或者:

function testFor() {
 bbq:
 for(var k=0;k<a.length;k++){
  console.log('444');
  ccc:
  for(var i=0;i<a.length;i++){
   ddd:
   for(var j=0;j<b.length;j++){
    if(j == 2){
     break;
    }
    console.log('j '+j);
   }
   console.log('i '+i);
  }
  console.log('k '+k);
 }
}
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

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

转载于:https://my.oschina.net/u/3970421/blog/2992683

### 如何在 JavaScript 中提前终止 `for` 循环JavaScript 中,有几种方法可以在满足特定条件时提前退出 `for` 循环。 #### 使用 `break` 关键字 当程序遇到 `break` 语句时会立即退出当前最内层的循环结构。这适用于所有的循环类型,包括 `for`、`while` 和 `do...while` 循环。 ```javascript for (let i = 0; i < 5; i++) { if (i === 3) { break; } console.log(i); } // 输出: 0, 1, 2 ``` #### 使用标签(Label)配合 `break` 如果存在嵌套多层循环的情况下想要跳出指定外层循环,则可以通过给该外层循环加一个标签来实现这一点[^1]。 ```javascript outerLoop: for (let i = 0; i < 3; i++) { for (let j = 0; j < 3; j++) { if (someCondition()) { break outerLoop; } } } ``` #### 抛出异常并捕获它 虽然这不是推荐的做法,但在某些特殊场景下确实可以用抛出自定义错误的方式来强制结束整个函数执行从而间接达到退出循环的效果。不过这种方式通常不被提倡因为其效率较低而且可读性差。 #### 返回 (`return`) 函数 在一个函数体内使用 `return` 可以立刻停止所有正在运行中的代码并且返回控制权给调用者;因此这也是一种有效的手段用于中途离开循环体。 ```javascript function processItems(items) { for (const item of items) { if (!isValid(item)) { return false; } // 继续处理有效项... } return true; } ``` 以上就是在 JavaScript 中提前终止 `for` 循环的一些常见方式。选择哪种取决于具体的应用场景和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值