今天寫帶代碼的時候遇到一段代碼,須要終止運行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循環而後外面的循環都會繼續循環