文章介紹了幾個在jQuery中非常有用的遍歷函數,遍歷函數是做麼的方便。當在它們一起使用時,它們將更加強大。也就是說,一個函數的輸出是另一個函數的輸入,它們是鏈式的。下面我們就來詳細探討下吧。
jQuery 遍歷函數包括了用於篩選、查找和串聯元素的方法。
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 函數 描述 .add() 將元素添加到匹配元素的集合中。 .andSelf() 把堆棧中之前的元素集添加到當前集合中。 .children() 獲得匹配元素集合中每個元素的所有子元素。 .closest() 從元素本身開始,逐級向上級元素匹配,並返回最先匹配的祖先元素。 .contents() 獲得匹配元素集合中每個元素的子元素,包括文本和注釋節點。 .each() 對 jQuery 對象進行迭代,為每個匹配元素執行函數。 .end() 結束當前鏈中最近的一次篩選操作,並將匹配元素集合返回到前一次的狀態。 .eq() 將匹配元素集合縮減為位於指定索引的新元素。 .filter() 將匹配元素集合縮減為匹配選擇器或匹配函數返回值的新元素。 .find() 獲得當前匹配元素集合中每個元素的後代,由選擇器進行篩選。 .first() 將匹配元素集合縮減為集合中的第一個元素。 .has() 將匹配元素集合縮減為包含特定元素的後代的集合。 .is() 根據選擇器檢查當前匹配元素集合,如果存在至少一個匹配元素,則返回 true。 .last() 將匹配元素集合縮減為集合中的最後一個元素。 .map() 把當前匹配集合中的每個元素傳遞給函數,產生包含返回值的新 jQuery 對象。 .next() 獲得匹配元素集合中每個元素緊鄰的同輩元素。 .nextAll() 獲得匹配元素集合中每個元素之後的所有同輩元素,由選擇器進行篩選(可選)。 .nextUntil() 獲得每個元素之後所有的同輩元素,直到遇到匹配選擇器的元素為止。 .not() 從匹配元素集合中刪除元素。 .offsetParent() 獲得用於定位的第一個父元素。 .parent() 獲得當前匹配元素集合中每個元素的父元素,由選擇器篩選(可選)。 .parents() 獲得當前匹配元素集合中每個元素的祖先元素,由選擇器篩選(可選)。 .parentsUntil() 獲得當前匹配元素集合中每個元素的祖先元素,直到遇到匹配選擇器的元素為止。 .prev() 獲得匹配元素集合中每個元素緊鄰的前一個同輩元素,由選擇器篩選(可選)。 .prevAll() 獲得匹配元素集合中每個元素之前的所有同輩元素,由選擇器進行篩選(可選)。 .prevUntil() 獲得每個元素之前所有的同輩元素,直到遇到匹配選擇器的元素為止。 .siblings() 獲得匹配元素集合中所有元素的同輩元素,由選擇器篩選(可選)。 .slice() 將匹配元素集合縮減為指定范圍的子集。each的用法
1.數組中的each
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 var arr = [ "one", "two", "three", "four"]; $.each(arr, function(){ alert(this); }); //上面這個each輸出的結果分別為:one,two,three,four var arr1 = [[1, 4, 3], [4, 6, 6], [7, 20, 9]] $.each(arr1, function(i, item){ alert(item[0]); }); //其實arr1為一個二維數組,item相當於取每一個一維數組, //item[0]相對於取每一個一維數組裡的第一個值 //所以上面這個each輸出分別為:1 4 7 var obj = { one:1, two:2, three:3, four:4}; $.each(obj, function(i) { alert(obj[i]); }); //這個each就有更厲害了,能循環每一個屬性 //輸出結果為:1 2 3 42.遍歷Dom元素中
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 <html> <head> <script type="text/javascript" src="/jquery/jquery.js"></script> <script type="text/javascript"> $(document).ready(function(){ $("button").click(function(){ $("li").each(function(){ alert($(this).text()) }); }); }); </script> </head> <body> <button>輸出每個列表項的值</button> <ul> <li>Coffee</li> <li>Milk</li> <li>Soda</li> </ul> </body> </html>依次彈出Coffee,Milk,Soda
3.each和map的比較
下面的例子是獲取每一個多框的ID值;
each方法:
定義一個空數組,通過each方法,往數組添加ID值;最後將數組轉換成字符串後,alert這個值;
?
1 2 3 4 5 6 7 8 $(function(){ var arr = []; $(":checkbox").each(function(index){ arr.push(this.id); }); var str = arr.join(","); alert(str); })map方法:
將每個:checkbox執行return this.id;並將這些返回值,自動的保存為jQuery對象,然後用get方法將其轉換成原生Javascript數組,再使用join方法轉換成字符串,最後alert這個值;
?
1 2 3 4 5 6 $(function(){ var str = $(":checkbox").map(function() { return this.id; }).get().join(); alert(str); })當有需一個數組的值的時候,用map方法,很方便。
4.jquery中使用each
例遍數組,同時使用元素索引和內容。(i是索引,n是內容)
代碼如下:
?
1 2 3 $.each( [0,1,2], function(i, n){ alert( "Item #" + i + ": " + n ); });例遍對象,同時使用成員名稱和變量內容。(i是成員名稱,n是變量內容)
代碼如下:
?
1 2 3 $.each( { name: "John", lang: "JS" }, function(i, n){ alert( "Name: " + i + ", Value: " + n ); });