麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

jQuery 遍歷函數(shù)詳解

2024-05-06 16:22:42
字體:
供稿:網(wǎng)友

文章介紹了幾個在jQuery中非常有用的遍歷函數(shù),遍歷函數(shù)是做么的方便。當(dāng)在它們一起使用時,它們將更加強(qiáng)大。也就是說,一個函數(shù)的輸出是另一個函數(shù)的輸入,它們是鏈?zhǔn)降摹O旅嫖覀兙蛠碓敿?xì)探討下吧。

jQuery 遍歷函數(shù)包括了用于篩選、查找和串聯(lián)元素的方法。

 

 
  1. 函數(shù) 描述 
  2. .add() 將元素添加到匹配元素的集合中。 
  3. .andSelf() 把堆棧中之前的元素集添加到當(dāng)前集合中。 
  4. .children() 獲得匹配元素集合中每個元素的所有子元素。 
  5. .closest() 從元素本身開始,逐級向上級元素匹配,并返回最先匹配的祖先元素。 
  6. .contents() 獲得匹配元素集合中每個元素的子元素,包括文本和注釋節(jié)點(diǎn)。 
  7. .each() 對 jQuery 對象進(jìn)行迭代,為每個匹配元素執(zhí)行函數(shù)。 
  8. .end() 結(jié)束當(dāng)前鏈中最近的一次篩選操作,并將匹配元素集合返回到前一次的狀態(tài)。 
  9. .eq() 將匹配元素集合縮減為位于指定索引的新元素。 
  10. .filter() 將匹配元素集合縮減為匹配選擇器或匹配函數(shù)返回值的新元素。 
  11. .find() 獲得當(dāng)前匹配元素集合中每個元素的后代,由選擇器進(jìn)行篩選。 
  12. .first() 將匹配元素集合縮減為集合中的第一個元素。 
  13. .has() 將匹配元素集合縮減為包含特定元素的后代的集合。 
  14. .is() 根據(jù)選擇器檢查當(dāng)前匹配元素集合,如果存在至少一個匹配元素,則返回 true。 
  15. .last() 將匹配元素集合縮減為集合中的最后一個元素。 
  16. .map() 把當(dāng)前匹配集合中的每個元素傳遞給函數(shù),產(chǎn)生包含返回值的新 jQuery 對象。 
  17. .next() 獲得匹配元素集合中每個元素緊鄰的同輩元素。 
  18. .nextAll() 獲得匹配元素集合中每個元素之后的所有同輩元素,由選擇器進(jìn)行篩選(可選)。 
  19. .nextUntil() 獲得每個元素之后所有的同輩元素,直到遇到匹配選擇器的元素為止。 
  20. .not() 從匹配元素集合中刪除元素。 
  21. .offsetParent() 獲得用于定位的第一個父元素。 
  22. .parent() 獲得當(dāng)前匹配元素集合中每個元素的父元素,由選擇器篩選(可選)。 
  23. .parents() 獲得當(dāng)前匹配元素集合中每個元素的祖先元素,由選擇器篩選(可選)。 
  24. .parentsUntil() 獲得當(dāng)前匹配元素集合中每個元素的祖先元素,直到遇到匹配選擇器的元素為止。 
  25. .prev() 獲得匹配元素集合中每個元素緊鄰的前一個同輩元素,由選擇器篩選(可選)。 
  26. .prevAll() 獲得匹配元素集合中每個元素之前的所有同輩元素,由選擇器進(jìn)行篩選(可選)。 
  27. .prevUntil() 獲得每個元素之前所有的同輩元素,直到遇到匹配選擇器的元素為止。 
  28. .siblings() 獲得匹配元素集合中所有元素的同輩元素,由選擇器篩選(可選)。 
  29. .slice() 將匹配元素集合縮減為指定范圍的子集。 

each的用法

1.數(shù)組中的each

 

 
  1. var arr = [ "one""two""three""four"];  
  2. $.each(arr, function(){  
  3. alert(this);  
  4. });  
  5. //上面這個each輸出的結(jié)果分別為:one,two,three,four  
  6.  
  7. var arr1 = [[1, 4, 3], [4, 6, 6], [7, 20, 9]]  
  8. $.each(arr1, function(i, item){  
  9. alert(item[0]);  
  10. });  
  11. //其實(shí)arr1為一個二維數(shù)組,item相當(dāng)于取每一個一維數(shù)組,  
  12. //item[0]相對于取每一個一維數(shù)組里的第一個值  
  13. //所以上面這個each輸出分別為:1 4 7  
  14.  
  15.  
  16. var obj = { one:1, two:2, three:3, four:4};  
  17. $.each(obj, function(i) {  
  18. alert(obj[i]);  
  19. });  
  20. //這個each就有更厲害了,能循環(huán)每一個屬性  
  21. //輸出結(jié)果為:1 2 3 4  

2.遍歷Dom元素中

 

 
  1. <html> 
  2. <head> 
  3. <script type="text/javascript" src="/jquery/jquery.js"></script> 
  4. <script type="text/javascript"
  5. $(document).ready(function(){ 
  6. $("button").click(function(){ 
  7. $("li").each(function(){ 
  8. alert($(this).text()) 
  9. }); 
  10. }); 
  11. }); 
  12. </script> 
  13. </head> 
  14. <body> 
  15. <button>輸出每個列表項(xiàng)的值</button> 
  16. <ul> 
  17. <li>Coffee</li> 
  18. <li>Milk</li> 
  19. <li>Soda</li> 
  20. </ul> 
  21. </body> 
  22. </html> 

依次彈出Coffee,Milk,Soda

3.each和map的比較

下面的例子是獲取每一個多框的ID值;

each方法:

定義一個空數(shù)組,通過each方法,往數(shù)組添加ID值;最后將數(shù)組轉(zhuǎn)換成字符串后,alert這個值;

 

 
  1. $(function(){ 
  2. var arr = []; 
  3. $(":checkbox").each(function(index){ 
  4. arr.push(this.id); 
  5. }); 
  6. var str = arr.join(","); 
  7. alert(str); 
  8. }) 

map方法:

將每個:checkbox執(zhí)行return this.id;并將這些返回值,自動的保存為jQuery對象,然后用get方法將其轉(zhuǎn)換成原生Javascript數(shù)組,再使用join方法轉(zhuǎn)換成字符串,最后alert這個值;

 

 
  1. $(function(){ 
  2. var str = $(":checkbox").map(function() { 
  3. return this.id; 
  4. }).get().join();  
  5. alert(str); 
  6. }) 

當(dāng)有需一個數(shù)組的值的時候,用map方法,很方便。

4.jquery中使用each

例遍數(shù)組,同時使用元素索引和內(nèi)容。(i是索引,n是內(nèi)容)

代碼如下:

 

 
  1. $.each( [0,1,2], function(i, n){ 
  2. alert( "Item #" + i + ": " + n ); 
  3. });  

例遍對象,同時使用成員名稱和變量內(nèi)容。(i是成員名稱,n是變量內(nèi)容)

代碼如下:

 

 
  1. $.each( { name: "John", lang: "JS" }, function(i, n){ 
  2. alert( "Name: " + i + ", Value: " + n ); 
  3. }); 

例遍dom元素,此處以一個input表單元素作為例子。

如果你dom中有一段這樣的代碼

 

 
  1. <input name="aaa" type="hidden" value="111" />  
  2. <input name="bbb" type="hidden" value="222" />  
  3. <input name="ccc" type="hidden" value="333" />  
  4. <input name="ddd" type="hidden" value="444"/>  

然后你使用each如下

代碼如下:

 

 
  1. $.each($("input:hidden"), function(i,val){ 
  2. alert(val); //輸出[object HTMLInputElement],因?yàn)樗且粋€表單元素。 
  3. alert(i); //輸出索引為0,1,2,3 
  4. alert(val.name); //輸出name的值 
  5. alert(val.value); //輸出value的值 
  6. });  

5.each中根據(jù)this查找元素

實(shí)現(xiàn)效果”回復(fù)”兩個字只有在鼠標(biāo)經(jīng)過的時候才顯示出來

 

 
  1. <ol class="commentlist"
  2. <li class="comment"
  3. <div class="comment-body"
  4. <p>嗨,第一層評論</p> 
  5. <div class="reply"
  6. <a href="#" class=".comment-reply-link">回復(fù)</a> 
  7. </div> 
  8. </div> 
  9. <ul class="children"
  10. <li class="comment"
  11. <div class="comment-body"
  12. <p>第二層評論</p> 
  13. <div class="reply"
  14. <a href="#" class=".comment-reply-link">回復(fù)</a> 
  15. </div> 
  16. </div></li> 
  17. </ul> 
  18. </li> 
  19. </ol> 

js代碼如下

 

 
  1. $("div.reply").hover(function(){ 
  2. $(this).find(".comment-reply-link").show(); 
  3. },function(){ 
  4. $(this).find(".comment-reply-link").hide(); 
  5. }); 

實(shí)現(xiàn)效果,驗(yàn)證判斷題是否都有選擇

html

 

 
  1. <ul id="ulSingle"
  2.  
  3. <li class="liStyle"
  4. 1. 阿斯頓按時<label id="selectTips" style="display: none" class="fillTims">請選擇</label> 
  5. <!--begin選項(xiàng)--> 
  6. <ul> 
  7.  
  8. <li class="liStyle2"
  9. <span id="repSingle_repSingleChoices_0_labOption_0">A </span>.阿薩德發(fā)<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl00$hidID" id="repSingle_repSingleChoices_0_hidID_0" value="1" /> 
  10. <input id="repSingle_repSingleChoices_0_cheSingleChoice_0" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl00$cheSingleChoice" /></li> 
  11.  
  12. <li class="liStyle2"
  13. <span id="repSingle_repSingleChoices_0_labOption_1">B </span>.阿薩德發(fā)<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl01$hidID" id="repSingle_repSingleChoices_0_hidID_1" value="2" /> 
  14. <input id="repSingle_repSingleChoices_0_cheSingleChoice_1" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl01$cheSingleChoice" /></li> 
  15.  
  16. <li class="liStyle2"
  17. <span id="repSingle_repSingleChoices_0_labOption_2">C </span>.阿斯頓<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl02$hidID" id="repSingle_repSingleChoices_0_hidID_2" value="3" /> 
  18. <input id="repSingle_repSingleChoices_0_cheSingleChoice_2" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl02$cheSingleChoice" /></li> 
  19.  
  20. </ul> 
  21. <!--end選項(xiàng)--> 
  22. <br /> 
  23. </li> 
  24.  
  25. </ul> 

js代碼

 

 
  1. //驗(yàn)證單選題是否選中 
  2. $("ul#ulSingle>li.liStyle").each(function (index) { 
  3. //選項(xiàng)個數(shù) 
  4. var count = $(this).find("ul>li>:checkbox").length; 
  5. var selectedCount = 0 
  6. for (var i = 0; i < count; i++) { 
  7. if ($(this).find("ul>li>:checkbox:eq(" + i + ")").attr("checked")) { 
  8. selectedCount++; 
  9. break
  10. if (selectedCount == 0) { 
  11. $(this).find("label#selectTips").show(); 
  12. return false
  13. else { 
  14. $(this).find("label#selectTips").hide(); 
  15. }) 

6.官方解釋

以下是官方的解釋:

jQuery.each(object, [callback])

概述

通用例遍方法,可用于例遍對象和數(shù)組。

不同于例遍 jQuery 對象的 $().each() 方法,此方法可用于例遍任何對象。回調(diào)函數(shù)擁有兩個參數(shù):第一個為對象的成員或數(shù)組的索引,第二個為對應(yīng)變量或內(nèi)容。如果需要退出 each 循環(huán)可使回調(diào)函數(shù)返回 false,其它返回值將被忽略。

參數(shù)

objectObject

需要例遍的對象或數(shù)組。

callback (可選)Function

每個成員/元素執(zhí)行的回調(diào)函數(shù)。

以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 国人精品视频在线观看 | 国产免费一级淫片a级中文 99国产精品自拍 | 日韩深夜视频 | 久久男人天堂 | 国产精品视频在 | h网站在线观看 | 视频一区二区三区在线播放 | 一级大片一级一大片 | 国产毛毛片一区二区三区四区 | 狠狠撸电影 | 亚洲亚色 | 中文字幕xxx| 国产瑟瑟视频 | 特级黄色一级毛片 | av在线网站观看 | 7777奇米成人四色影视 | 蜜桃传媒视频麻豆第一区免费观看 | 精品中文字幕久久久久四十五十骆 | 久久久久久久久久久久久国产精品 | 亚洲午夜一区二区三区 | 亚州综合图片 | 成人偷拍片视频在线观看 | 成人三级电影网址 | 国产精品久久久久久久久久iiiii | 国产精品久久久久无码av | 国产妇女乱码一区二区三区 | 欧美性生视频 | 国产午夜精品久久久久久久蜜臀 | 国产成人综合在线视频 | 精品一区二区三区在线观看视频 | 欧美日韩中文字幕在线 | 天天夜碰日日摸日日澡性色av | 久久国产亚洲精品 | 欧美一级高潮 | 毛片在线免费视频 | 久久久久久久亚洲视频 | 中文字幕一二区 | 国产高潮好爽受不了了夜色 | 亚洲国产一区二区三区 | 狠狠操天天射 | 国产视频在线播放 |