each()函數是基本上所有的框架都提供了的一個工具類別函數,透過它,你可以遍歷物件、陣列的屬性值並進行處理。 jQuery和jQuery對像都實現了該方法,對於jQuery對象,只是把each方法簡單的進行了委託:把jQuery對像作為第一個參數傳遞給jQuery的each方法.換句話說:jQuery提供的each方法是對參數一提供的物件的中所有的子元素逐一進行方法呼叫。而jQuery物件提供的each方法則是對jQuery內 部的子元素進行逐一呼叫。
下面提一下each的幾種常用的用法
#1. each處理一維數組
var arr1 = [ "aaa", "bbb", "ccc" ]; $.each(arr1, function(i,val){ alert(i); alert(val); });
alert( i)將輸出0,1,2
alert(val)將輸出aaa,bbb,ccc
#2. each處理二維陣列
var arr2 = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']] $.each(arr, function(i, item){ alert(i); alert(item); });
arr2為一個二維數組,item相當於取這二維數組中的每一個數組。
item[0]相對於取每一個一維數組裡的第一個值
alert(i)將輸出為0,1,2,因為這二維數組含有3個數組元素
alert(item)將輸出為 ['a', 'aa', 'aaa'],['b', 'bb', 'bbb'],['c', 'cc', 'ccc']
對此二位數組的處理稍作變更之後
var arr = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']] $.each(arr, function(i, item){ $.each(item,function(j,val){ alert(j); alert(val); }); });
alert(j)將輸出為0,1,2,0,1,2,0,1 ,2
alert(val)將輸出為a,aa,aaa,b,bb,bbb,c,cc,ccc
each處理json數據,這個each就有更厲害了,能循環每一個屬性
var obj = { one:1, two:2, three:3}; each(obj, function(key, val) { alert(key); alert(val); });
這裡alert(key)將輸出one two three
alert(val)將輸出one,1,two,2,three,3
這邊為何key不是數字而是屬性呢,因為json格式內是一組無序的屬性-值,既然無序,又何來數字呢。
而這個val等同於obj[key]
ecah處理dom元素,此處以一個input表單元素作為範例。
如果你dom中有一段這樣的程式碼
faccfcae027ff734f73dd06266eca48e
cc896bc9d5d56de012ad70ceb9db5a87
a64ed2e9863cf3d87033948a4a36efde
7c73384ce43e09c1a18c66347be13bdb
然後你使用each如下
$.each($("input:hidden"), function(i,val){ alert(val); alert(i); alert(val.name); alert(val.value); });
那麼,alert(val)將輸出[object HTMLInputElement],因為它是一個表單元素。
alert(i)將輸出為0,1,2,3
#alert(val.name);將輸出aaa,bbb,ccc,ddd,如果使用this. name將輸出相同的結果
alert(val.value); 將輸出111,222,333,444,如果使用this.value將輸出相同的結果
#each(callback) 以每一個匹配的元素作為上下文來執行一個函數。
意味著,每次執行傳遞進來的函數時,函數中的this關鍵字都指向一個不同的DOM元素(每次都是一個不同的匹配元素)。而且,在每次執行函數時,都會給函數傳遞一個表示作為執行環境的元素在匹配的元素集合中所處位置的數字值作為參數(從零開始的整形)。回傳 'false' 將停止循環 (就像在普通的循環中使用 'break')。傳回 'true' 跳至下一個循環(就像在普通的循環中使用'continue')。
而後面的callback 則是回呼函數,指示遍歷元素的時候應該給予的運算。先看下面的一個簡單的例子:
迭代兩個圖像,並設定它們的 src 屬性。注意:此處 this 指涉的是 DOM 物件而非 jQuery 物件。
each() 方法規定為每個符合元素規定執行的函數。
提示:傳回 false 可用於及早停止循環。
語法
$(selector).each(function(index,element))參數 描述
function(index,element) 必要。為每個匹配元素規定運行的函數。
•index - 選擇器的 index 位置
•element - 目前的元素(也可使用 "this" 選擇器 )
$("button").click(function(){ $("li").each(function(){ alert($(this).text()) }); });
那怎么跳出each呢
jquery再遍历选定的对象时候用each比较方便。有种应用是找到里面符合条件的对象后,要跳出这个循环。
javascript的跳出循环一般用break.
同事遇到这个问题,下意识 的用了break,想跳出这个循环。结果报错
SyntaxError: unlabeled break must be inside loop or switch
经查,应该用一个 在回调函数里return false即可,大多数jq的方法都是如此的
以上是jquery中的each()方法使用實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!