亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

淺析jQuery 遍歷函數,javascript中的each遍歷

2019-11-20 09:54:45
字體:
來源:轉載
供稿:網友

jQuery 遍歷函數

jQuery 遍歷函數包括了用于篩選、查找和串聯元素的方法。

函數 描述
.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

 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 4

2.遍歷Dom元素中

<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這個值;

$(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這個值;

$(function(){  var str = $(":checkbox").map(function() {    return this.id;  }).get().join();    alert(str);})

當有需一個數組的值的時候,用map方法,很方便。

 4.jquery中使用each

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

代碼如下:

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

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

代碼如下:
$.each( { name: "John", lang: "JS" }, function(i, n){alert( "Name: " + i + ", Value: " + n );}); 

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

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

<input name="aaa" type="hidden" value="111" />

<input name="bbb" type="hidden" value="222" />

<input name="ccc" type="hidden" value="333" />

<input name="ddd" type="hidden" value="444"/>

然后你使用each如下

代碼如下:

 

$.each($("input:hidden"), function(i,val){alert(val); //輸出[object HTMLInputElement],因為它是一個表單元素。alert(i); //輸出索引為0,1,2,3alert(val.name); //輸出name的值alert(val.value); //輸出value的值});

5.each中根據this查找元素

實現效果”回復”兩個字只有在鼠標經過的時候才顯示出來

<ol class="commentlist">  <li class="comment">    <div class="comment-body">     <p>嗨,第一層評論</p>     <div class="reply">      <a href="#" class=".comment-reply-link">回復</a>     </div>    </div>    <ul class="children">     <li class="comment">      <div class="comment-body">      <p>第二層評論</p>      <div class="reply">       <a href="#" class=".comment-reply-link">回復</a>      </div>     </div></li>    </ul>  </li></ol>

js代碼如下

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

實現效果,驗證判斷題是否都有選擇

html

<ul id="ulSingle">        <li class="liStyle">        1.  阿斯頓按時<label id="selectTips" style="display: none" class="fillTims">請選擇</label>        <!--begin選項-->        <ul>                        <li class="liStyle2">                <span id="repSingle_repSingleChoices_0_labOption_0">A     </span>.阿薩德發<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl00$hidID" id="repSingle_repSingleChoices_0_hidID_0" value="1" />                <input id="repSingle_repSingleChoices_0_cheSingleChoice_0" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl00$cheSingleChoice" /></li>                          <li class="liStyle2">                <span id="repSingle_repSingleChoices_0_labOption_1">B     </span>.阿薩德發<input type="hidden" name="repSingle$ctl00$repSingleChoices$ctl01$hidID" id="repSingle_repSingleChoices_0_hidID_1" value="2" />                <input id="repSingle_repSingleChoices_0_cheSingleChoice_1" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl01$cheSingleChoice" /></li>                          <li class="liStyle2">                <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" />                <input id="repSingle_repSingleChoices_0_cheSingleChoice_2" type="checkbox" name="repSingle$ctl00$repSingleChoices$ctl02$cheSingleChoice" /></li>                    </ul>        <!--end選項-->        <br />      </li>    </ul>

js代碼

//驗證單選題是否選中    $("ul#ulSingle>li.liStyle").each(function (index) {      //選項個數      var count = $(this).find("ul>li>:checkbox").length;      var selectedCount = 0      for (var i = 0; i < count; i++) {        if ($(this).find("ul>li>:checkbox:eq(" + i + ")").attr("checked")) {          selectedCount++;          break;        }      }      if (selectedCount == 0) {        $(this).find("label#selectTips").show();        return false;      }      else {        $(this).find("label#selectTips").hide();      }    })

ps:傳說中attr("property", "value");在部分瀏覽器中不管用可以用prop,如果只是判斷可以用$(this).find("ul>li>:checkbox:eq(" + i + ")").is(":checked");

 6.官方解釋

以下是官方的解釋:

jQuery.each(object, [callback])

概述

通用例遍方法,可用于例遍對象和數組。

不同于例遍 jQuery 對象的 $().each() 方法,此方法可用于例遍任何對象?;卣{函數擁有兩個參數:第一個為對象的成員或數組的索引,第二個為對應變量或內容。如果需要退出 each 循環可使回調函數返回 false,其它返回值將被忽略。

參數

objectObject

需要例遍的對象或數組。

callback (可選)Function

每個成員/元素執行的回調函數。

以上這篇淺析jQuery 遍歷函數,javascript中的each遍歷就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲午夜精品久久久久久久久久久久| 精品久久久久久中文字幕一区奶水| 国模私拍一区二区三区| 久久国产精彩视频| 日韩av中文字幕在线免费观看| 欧美日韩视频在线| 国产亚洲激情视频在线| 久久精品久久久久| 成人激情视频在线播放| 成人自拍性视频| 中文字幕亚洲一区在线观看| 欧美老女人bb| 久久免费视频在线| 精品国产欧美一区二区三区成人| 日韩国产欧美精品在线| 久久精品国产精品亚洲| 91精品91久久久久久| 欧美激情视频给我| 影音先锋欧美精品| 中文字幕久久亚洲| 青青草99啪国产免费| 亚洲国产天堂久久国产91| 日韩暖暖在线视频| 欧美限制级电影在线观看| 一本一道久久a久久精品逆3p| 欧美又大又粗又长| 成人黄色免费看| 视频在线一区二区| 亚洲黄色www网站| 欧美人在线视频| 欧美亚洲日本黄色| 久久久影视精品| 在线亚洲国产精品网| 欧美午夜xxx| 国产精品久久久久久久美男| 狠狠躁天天躁日日躁欧美| 亚洲欧洲在线免费| 国产精品视频网站| 日韩在线观看高清| 日韩av第一页| 国内揄拍国内精品| 狠狠躁夜夜躁人人躁婷婷91| 欧美精品激情在线| 黑人巨大精品欧美一区二区三区| 九九热这里只有在线精品视| 国产精品激情av电影在线观看| 午夜精品一区二区三区视频免费看| 国产成人精品久久二区二区| 亚洲毛片在线观看.| 麻豆精品精华液| 欧美精品在线免费播放| 久久久久久亚洲精品不卡| 中文字幕亚洲一区二区三区五十路| 国产精品久久久久久久久久99| 亚洲欧洲在线视频| 亚洲精品国产精品久久清纯直播| 国产午夜一区二区| 欧美激情精品久久久久久| 欧美日韩国产丝袜另类| 欧美韩日一区二区| 亚洲激情电影中文字幕| 美女福利精品视频| 国产91在线播放| 2020欧美日韩在线视频| 欧美一区二区.| 亚洲免费电影一区| 亚洲精品第一国产综合精品| 在线观看日韩欧美| 黄色成人av网| 亚洲男女自偷自拍图片另类| 亚洲另类图片色| 国产精品久久久久久久久借妻| 永久免费看mv网站入口亚洲| 日韩精品一区二区视频| 欧美视频在线观看免费网址| 国产精品成人av性教育| 91精品在线观看视频| 97在线看免费观看视频在线观看| 一区二区三区回区在观看免费视频| 在线观看免费高清视频97| 色综合亚洲精品激情狠狠| 97在线看福利| 中文字幕日韩视频| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲综合自拍一区| 日韩在线欧美在线国产在线| 亚洲午夜未满十八勿入免费观看全集| 亚洲乱码国产乱码精品精| 日韩电影中文 亚洲精品乱码| 亚洲精品欧美日韩专区| 国产91精品黑色丝袜高跟鞋| 久久久久久久久久久久久久久久久久av| 中日韩美女免费视频网站在线观看| 亚洲免费人成在线视频观看| 成人欧美在线视频| 亚洲国产精品成人va在线观看| 91精品免费视频| 国产成人在线亚洲欧美| 国产免费一区视频观看免费| 精品亚洲一区二区三区在线观看| 亚洲精品一区二区久| 国产精品久久视频| 亚洲深夜福利在线| 久久好看免费视频| 7m第一福利500精品视频| 欧美大片免费观看在线观看网站推荐| 51午夜精品视频| 国产精品69久久| 国产精品免费看久久久香蕉| 久久99精品久久久久久噜噜| 在线成人激情黄色| 亚洲天堂第一页| 在线一区二区日韩| 日韩久久免费视频| 中日韩美女免费视频网站在线观看| 亚洲激情小视频| 欧美成人精品三级在线观看| 视频直播国产精品| 久久国产精品久久国产精品| 精品久久久免费| 欧美电影免费观看电视剧大全| 97婷婷大伊香蕉精品视频| 久久久久久18| 久久精品视频亚洲| 亚洲第一偷拍网| 亚洲男人天堂网站| 在线播放精品一区二区三区| 精品香蕉一区二区三区| 国产精品大片wwwwww| 久99九色视频在线观看| 国内精品久久久久久影视8| 日韩精品久久久久久福利| 免费av一区二区| 亚洲永久在线观看| 亚洲成av人乱码色午夜| 国产欧美最新羞羞视频在线观看| 久久国产精品99国产精| 国产精品久久久久久av下载红粉| 亚洲91精品在线观看| 国产精品7m视频| 亚洲欧洲美洲在线综合| 91香蕉电影院| 91精品国产高清久久久久久| 国产成人精品a视频一区www| 亚洲天堂网在线观看| 亚洲国产精品yw在线观看| 精品中文字幕久久久久久| 中文字幕无线精品亚洲乱码一区| 欧美成人免费大片| 日本一区二区三区四区视频| 亚洲欧美一区二区精品久久久| 亚洲精品中文字幕女同| 国产91免费看片| 国产精品吹潮在线观看| 亚洲一区二区三区在线视频| 亚洲国语精品自产拍在线观看| 这里只有精品在线观看| 欧美国产日韩一区二区| 日韩精品久久久久久久玫瑰园| 国产精品久久色| 久久国产精品久久久久久| 国产精品视频区| 国产欧美日韩中文字幕| 国产精品丝袜视频|