今天写带代码的时候遇到一段代码,须要终止运行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的地方。json
示例代码函数
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后的代码永远不会被执行;url
2.如遇到逻辑特别复杂多层循环的时候,会遇到一些迭代器之类的方法, 这种迭代器实现的不一样,会出现另外一种状况,即不会跳出任何循环, 循环仍然继续,只是当前循环if后的代码不会被执行一次,下一次循环开始时, 仍然会执行if后的代码.net
如:code
var cc = 'xx'; Object.keys(o).forEach(function(key) { var val = o[key]; if(cc == key){ return false; } console.log(key); });ip
此外还有作用域
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循环而后外面的循环都会继续循环