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


Posted in Javascript onOctober 04, 2018

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

<script>
var Tid="55555";
var 3watercp = [
{id:66666,Cpurl:"https://baidu.com"},
{id:55555,Cpurl:"https://3water.com"}
];
 
 
for(var i = 0; i < 3watercp.length; i++){
	if(3watercp[i].id==Tid){
	var	thevalue=3watercp[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

可见 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外层循环
  }
 }
}


或者:
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);
 }
}

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

Javascript 相关文章推荐
JQuery从头学起第三讲
Jul 06 Javascript
JavaScript 实现类的多种方法实例
May 01 Javascript
jQuery实现的Div窗口震动特效
Jun 09 Javascript
基于jQuery实现的旋转彩圈实例
Jun 26 Javascript
javascript的正则匹配方法学习
Feb 24 Javascript
vue.js学习笔记之绑定style样式和class列表
Oct 31 Javascript
基于touch.js手势库+zepto.js插件开发图片查看器(滑动、缩放、双击缩放)
Nov 17 Javascript
基于BootStrap与jQuery.validate实现表单提交校验功能
Dec 22 Javascript
JS实现移动端判断上拉和下滑功能
Aug 07 Javascript
vue-cli项目中使用Mockjs详解
May 14 Javascript
js实现文章目录索引导航(table of content)
May 10 Javascript
vue-i18n实现中英文切换的方法
Jul 06 Javascript
iView-admin 动态路由问题的解决方法
Oct 03 #Javascript
Angular resolve基础用法详解
Oct 03 #Javascript
解决angularjs service中依赖注入$scope报错的问题
Oct 02 #Javascript
angular.js实现列表orderby排序的方法
Oct 02 #Javascript
Angularjs实现数组随机排序的方法
Oct 02 #Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
Oct 02 #Javascript
angularjs获取到My97DatePicker选中的值方法
Oct 02 #Javascript
You might like
apache mysql php 源码编译使用方法
2012/05/03 PHP
php牛逼的面试题分享
2013/01/18 PHP
基于magic_quotes_gpc与magic_quotes_runtime的区别与使用介绍
2013/04/22 PHP
一个php生成16位随机数的代码(两种方法)
2014/09/16 PHP
两个php日期控制类实例
2014/12/09 PHP
PHP 进度条函数的简单实例
2017/09/19 PHP
javascript完美拖拽的实现方法
2013/09/29 Javascript
JavaScript里四舍五入函数round用法实例
2015/04/06 Javascript
js 获取范围内的随机数实例代码
2016/08/02 Javascript
JS中script标签defer和async属性的区别详解
2016/08/12 Javascript
在线引用最新jquery文件的实现方法
2016/08/26 Javascript
简单的js计算器实现
2016/10/26 Javascript
详解Angular CLI + Electron 开发环境搭建
2017/07/20 Javascript
详解从Vue-router到html5的pushState
2018/07/21 Javascript
微信小程序支付PHP代码
2018/08/23 Javascript
微信小程序实现底部导航
2018/11/05 Javascript
关于React动态加载路由处理的相关问题
2019/01/07 Javascript
微信小程序时间轴实现方法示例
2019/01/14 Javascript
koa+jwt实现token验证与刷新功能
2019/05/30 Javascript
微信小程序保持session会话的方法
2020/03/20 Javascript
解决Antd Table组件表头不对齐的问题
2020/10/27 Javascript
[01:11:28]DOTA2-DPC中国联赛定级赛 RNG vs Phoenix BO3第一场 1月8日
2021/03/11 DOTA
python使用pil进行图像处理(等比例压缩、裁剪)实例代码
2017/12/11 Python
Python2包含中文报错的解决方法
2018/07/09 Python
python设计微型小说网站(基于Django+Bootstrap框架)
2019/07/08 Python
python3+django2开发一个简单的人员管理系统过程详解
2019/07/23 Python
HTML5地理定位_动力节点Java学院整理
2017/07/12 HTML / CSS
香港最新科技与优质家居产品购物网站:J SELECT
2018/08/21 全球购物
数据库什么时候应该被重组
2012/11/02 面试题
软件工程毕业生自荐信
2014/07/04 职场文书
男方婚礼答谢词
2015/01/20 职场文书
详解Redis瘦身指南
2021/05/26 Redis
python自动计算图像数据集的RGB均值
2021/06/18 Python
mysql脏页是什么
2021/07/26 MySQL
抖音动画片,皮皮虾,《治愈系》动画在用这首REMIX作为背景音乐,Anak ,The last world with you完整版
2022/03/16 杂记
Redis基本数据类型哈希Hash常用操作命令
2022/06/01 Redis