<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

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

       

      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,3
      alert(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.&nbsp;&nbsp;阿斯頓按時<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
      每個成員/元素執行的回調函數。

      posted @ 2013-04-05 12:16  nd  閱讀(124889)  評論(6)    收藏  舉報
      主站蜘蛛池模板: 99在线视频免费观看| 性姿势真人免费视频放| 国产视色精品亚洲一区二区| 国产原创自拍三级在线观看| 北岛玲中文字幕人妻系列| 亚洲国产精品久久一线不卡| 麻豆tv入口在线看| 久久成人伊人欧洲精品| 99久久无码私人网站| 国产精品自在自线免费观看| 亚洲成熟女人av在线观看| 人成午夜免费大片| 亚洲 欧美 综合 另类 中字| 成人免费无遮挡在线播放| 国产精品久久一区二区三区| 丁香五月婷激情综合第九色| 国精无码欧精品亚洲一区| 激情五月开心婷婷深爱| 亚洲成av人最新无码不卡短片| 久久久久亚洲AV色欲av| 精品亚洲香蕉久久综合网| 免费人成视频在线视频电影| 中文字幕色偷偷人妻久久| 国产在线亚州精品内射| 国产不卡在线一区二区| 久热这里只有精品视频3| 人妻聚色窝窝人体WWW一区| 久久伊99综合婷婷久久伊| 国内精品无码一区二区三区| 日本黄漫动漫在线观看视频| 精品国产一区二区三区av片| 一区二区三区放荡人妻| 色综合久久综合中文综合网| 国产在线自拍一区二区三区| 丁香五月亚洲综合深深爱| 妺妺窝人体色www聚色窝仙踪| 久久人妻国产精品| 无码人妻人妻经典| 午夜福利国产精品视频| 99久久国产精品无码| 亚洲一区二区三区自拍麻豆|