0. 前言
也許我們通過 jquery 的循環方法進行數組遍歷,但是當不符合條件時,怎么跳出當前循環?(即用each方法內,當不滿足條件時想break跳出循環體,想continue繼續執行下一個循環遍歷),我們經常會習慣JS中的break何continue,但是使用之后沒有效果,因為在JQuery中沒有這兩條命令,非其關鍵字。
1. JQuery each循環,要實現break和continue的功能
break ----用return false;
continue --用return ture;
2. JQuery怎么跳出當前的each循環
API 上的說明只有跳出整個循環(如果需要退出 each 循環可使回調函數返回 false,其它返回值將被忽略。)
return false;——跳出所有循環;相當於 javascript 中的 break 效果。
return true;——跳出當前循環,進入下一個循環;相當於 javascript 中的 continue 效果
例子代碼如下:
$(function (){ $("input[type='text']").each(function (i){ var _val=$(this).val(); alert(_val); if(_val=='2'){ return false; //跳出循環 } }) });
3. JQuery each方法跳出循環並獲得返回值的方法
return false:將停止循環 (就像在普通的循環中使用 'break')。
return true:跳至下一個循環(就像在普通的循環中使用'continue')。
代碼如下:
function test(){ var success = false; $(..).each(function () { if (..) { success = true; return false; } }); return success ; }
JQuery是對象鏈,所以$(..).each()返回的還是對象集合。each(function(){}):是回調函數,在回調函數里不能返回結果到回調函數each外面。
四. 參考