JQuery選擇器

jQuery 選擇器允許對 HTML 元素組或單個元素進行操作。

jQuery 選擇器基於元素的 id、類、類型、屬性、屬性值等"查找"(或選擇)HTML 元素。 它基於已經存在的CSS 選擇器,除此之外,它還有一些自定義的選擇器。

jQuery 中所有選擇器都以美元符號開頭:$()。

如果你有興趣可以參考本文章源碼素材和我一起寫:鏈接:https://pan.baidu.com/s/1Qy2myx-Vi7XDib34kPdBrQ
提取碼:z4c7

1. 基本選擇器

            1. 標籤選擇器(元素選擇器)

                * 語法: $("html標籤名") 獲得所有匹配標籤名稱的元素

            2. id選擇器

                * 語法: $("#id的屬性值") 獲得與指定id屬性值匹配的元素

            3. 類選擇器

                * 語法: $(".class的屬性值") 獲得與指定的class屬性值匹配的元素

            4. 並集選擇器:

                * 語法: $("選擇器1,選擇器2....") 獲取多個選擇器選中的所有元素

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>基本選擇器</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   <script  src="../js/jquery-3.3.1.min.js"></script>
   <style type="text/css">
         div,span{
             width: 180px;
             height: 180px;
             margin: 20px;
             background: #9999CC;
             border: #000 1px solid;
            float:left;
             font-size: 17px;
             font-family:Roman;
         }
         
         div .mini{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         div .mini01{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         
         
    </style>
   <script type="text/javascript">
        $(function () {
            // <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
            
            // <input type="button" value="改變 id 爲 one 的元素的背景色爲 紅色"  id="b1"/>
            $("#b1").click(function () {
                $("#one").css("backgroundColor","pink");
            });
            $("#b2").click(function () {
                // <input type="button" value=" 改變元素名爲 <div> 的所有元素的背景色爲 紅色"  id="b2"/>
                $("div").css("backgroundColor","pink");
            })
            $("#b3").click(function () {
            // <input type="button" value=" 改變 class 爲 mini 的所有元素的背景色爲 紅色"  id="b3"/>
                $(".mini").css("backgroundColor","pink");
            })
            $("#b4").click(function () {
            // <input type="button" value=" 改變所有的<span>元素和 id 爲 two 的元素的背景色爲紅色"  id="b4"/>
                $("span,#two").css("backgroundColor","pink");
            })
        })
   </script>
   
   </head>
    
   <body>
            
       <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
       <input type="button" value="改變 id 爲 one 的元素的背景色爲 紅色"  id="b1"/>
       <input type="button" value=" 改變元素名爲 <div> 的所有元素的背景色爲 紅色"  id="b2"/>
       <input type="button" value=" 改變 class 爲 mini 的所有元素的背景色爲 紅色"  id="b3"/>
       <input type="button" value=" 改變所有的<span>元素和 id 爲 two 的元素的背景色爲紅色"  id="b4"/>
      
       <h1>有一種奇蹟叫堅持</h1>
       <h2>自信源於努力</h2>
       
      <div id="one">
           id爲one       
       </div>
      
       <div id="two" class="mini" >
             id爲two   class是 mini
             <div  class="mini" >class是 mini</div>
       </div>
      
       <div class="one" >
             class是 one
             <div  class="mini" >class是 mini</div>
            <div  class="mini" >class是 mini</div>
       </div>
       <div class="one" >
           class是 one
             <div  class="mini01" >class是 mini01</div>
            <div  class="mini" >class是 mini</div>
      </div>
      
      <span class="spanone">class爲spanone的span元素</span>
      <span class="mini">class爲mini的span元素</span>
      
      <input type="text" value="zhang" id="username" name="username">
   
   </body>
</html>

運行結果:

點擊按鈕一:

點擊按鈕二:

點擊按鈕三:

點擊按鈕四:

 

        2. 層級選擇器
            1. 後代選擇器
                * 語法: $("A B ") 選擇A元素內部的所有B元素       
            2. 子選擇器
                * 語法: $("A > B") 選擇A元素內部的所有B子元素

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>層次選擇器</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   <script  src="../js/jquery-3.3.1.min.js"></script>
   <style type="text/css">
         div,span{
             width: 180px;
             height: 180px;
             margin: 20px;
             background: #9999CC;
             border: #000 1px solid;
            float:left;
             font-size: 17px;
             font-family:Roman;
         }
         div .mini{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         div .mini01{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
    </style>
    <script type="text/javascript">
        $(function () {
            // <input type="button" value=" 改變 <body> 內所有 <div> 的背景色爲紅色"  id="b1"/>
            $("#b1").click(function () {
                $("body div").css("backgroundColor","pink");
            });
            // <input type="button" value=" 改變 <body> 內子 <div> 的背景色爲 紅色"  id="b2"/>
            $("#b2").click(function () {
                $("body>div").css("backgroundColor","pink");
            });
        });
      
   </script>
   
   </head>
    
   <body>
            
       <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
       <input type="button" value=" 改變 <body> 內所有 <div> 的背景色爲紅色"  id="b1"/>
       <input type="button" value=" 改變 <body> 內子 <div> 的背景色爲 紅色"  id="b2"/>
      
       <h1>有一種奇蹟叫堅持</h1>
       <h2>自信源於努力</h2>
       
        <div id="one">
           id爲one  
           
       </div>
      
       <div id="two" class="mini" >
             id爲two   class是 mini
             <div  class="mini" >class是 mini</div>
      </div>
      
       <div class="one" >
             class是 one
             <div  class="mini" >class是 mini</div>
            <div  class="mini" >class是 mini</div>
       </div>
       <div class="one">
           class是 one
             <div  class="mini01" >class是 mini01</div>
            <div  class="mini" >class是 mini</div>
      </div>
      
      
      <span class="spanone">    span
      </span>
      
   </body>
  
   
</html>

運行結果:

運行前:

點擊按鈕一:

點擊按鈕二:

 

        3. 屬性選擇器

            1. 屬性名稱選擇器

                * 語法: $("A[屬性名]") 包含指定屬性的選擇器

            2. 屬性選擇器

                * 語法: $("A[屬性名='值']") 包含指定屬性等於指定值的選擇器

            3. 複合屬性選擇器

                * 語法: $("A[屬性名='值'][]...") 包含多個屬性條件的選擇器

            4.

                *語法:$["A[屬性名!='值']"]匹配所有不含有指定的屬性,或者屬性不等於特定值的元素。

            5.

                *語法:$["A[屬性名^='值']"]匹配給定的屬性是以某些值開始的元素

            6.

                *語法:$["A[屬性名$='值']"]匹配給定的屬性是以某些值結尾的元素

            7.

                *語法:$["A[屬性名*='值']"]匹配給定的屬性是以包含某些值的元素

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>屬性過濾選擇器</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   <script  src="../js/jquery-3.3.1.min.js"></script>
   <style type="text/css">
         div,span{
             width: 180px;
             height: 180px;
             margin: 20px;
             background: #9999CC;
             border: #000 1px solid;
            float:left;
             font-size: 17px;
             font-family:Roman;
         }
         
         div .mini{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         div .mini01{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         div.visible{
            display:none;
         }
    </style>
    <script type="text/javascript">
         $(function () {
             //    <input type="button" value=" 含有屬性title 的div元素背景色爲粉色"  id="b1"/>
             $("#b1").click(function () {
                $("div[title]").css("backgroundColor","pink");
             });
             // <input type="button" value=" 屬性title值等於test的div元素背景色爲粉色"  id="b2"/>
             $("#b2").click(function () {
                 $("div[title='test']").css("backgroundColor","pink");
             });
             // <input type="button" value=" 屬性title值不等於test的div元素(沒有屬性title的也將被選中)背景色爲粉色"  id="b3"/>
             $("#b3").click(function () {
                 $("div[title!='test']").css("backgroundColor","pink");
             });
             // <input type="button" value=" 屬性title值 以te開始 的div元素背景色爲粉色"  id="b4"/>
             $("#b4").click(function () {
                 $("div[title^='te']").css("backgroundColor","pink");
             });
             // <input type="button" value=" 屬性title值 以est結束 的div元素背景色爲粉色"  id="b5"/>
             $("#b5").click(function () {
                 $("div[title$='est']").css("backgroundColor","pink");
             });
             // <input type="button" value="屬性title值 含有es的div元素背景色爲粉色"  id="b6"/>
             $("#b6").click(function () {
                 $("div[title*='es']").css("backgroundColor","pink");
             });
             // <input type="button" value="選取有屬性id的div元素,然後在結果中選取屬性title值含有“es”的 div 元素背景色爲粉色"  id="b7"/>
             $("#b7").click(function () {
                 $("div[id][title*='es']").css("backgroundColor","pink");
             });
         })
   </script>
   </head>
    
   <body>
            
       <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
       <input type="button" value=" 含有屬性title 的div元素背景色爲粉色"  id="b1"/>
       <input type="button" value=" 屬性title值等於test的div元素背景色爲粉色"  id="b2"/>
       <input type="button" value=" 屬性title值不等於test的div元素(沒有屬性title的也將被選中)背景色爲粉色"  id="b3"/>
       <input type="button" value=" 屬性title值 以te開始 的div元素背景色爲粉色"  id="b4"/>
       <input type="button" value=" 屬性title值 以est結束 的div元素背景色爲粉色"  id="b5"/>
       <input type="button" value="屬性title值 含有es的div元素背景色爲粉色"  id="b6"/>
       <input type="button" value="選取有屬性id的div元素,然後在結果中選取屬性title值含有“es”的 div 元素背景色爲粉色"  id="b7"/>
       
       
      <div id="one">
           id爲one   div  
       </div>
      
       <div id="two" class="mini"  title="test">
             id爲two   class是 mini  div  title="test"
             <div  class="mini" >class是 mini</div>
      </div>
      
       <div class="visible" >
             class是 one
             <div  class="mini" >class是 mini</div>
            <div  class="mini" >class是 mini</div>
       </div>
       <div class="one" title="test02">
           class是 one    title="test02"
             <div  class="mini01" >class是 mini01</div>
            <div  class="mini" style="margin-top:0px;">class是 mini</div>
      </div>
      <div class="visible" >
           這是隱藏的
      </div>
      
      <div class="one">
         
      </div>
      
      <div id="mover" >
           動畫
      </div>
      
      <input type="text" value="zhang" id="username" name="username">
   </body>
</html>

運行結果:

運行前:

點擊按鈕一:

點擊按鈕二:

點擊按鈕三:

點擊按鈕四:

點擊按鈕五:

點擊按鈕六:

點擊按鈕七:

 

 

        4. 過濾選擇器

            1. 首元素選擇器

                * 語法: :first 獲得選擇的元素中的第一個元素

            2. 尾元素選擇器

                * 語法: :last 獲得選擇的元素中的最後一個元素

            3. 非元素選擇器

                * 語法: :not(selector) 不包括指定內容的元素

            4. 偶數選擇器

                * 語法: :even  偶數,從 0 開始計數

            5. 奇數選擇器

                * 語法: :odd  奇數,從 0 開始計數

            6. 等於索引選擇器

                * 語法: :eq(index)  指定索引元素

            7. 大於索引選擇器

                * 語法: :gt(index)  大於指定索引元素

            8. 小於索引選擇器

                * 語法: :lt(index)   小於指定索引元素

            9. 標題選擇器

                * 語法: :header  獲得標題(h1~h6)元素,固定寫法

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>基本過濾選擇器</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   <script  src="../js/jquery-3.3.1.min.js"></script>
   <style type="text/css">
         div,span{
             width: 180px;
             height: 180px;
             margin: 20px;
             background: #9999CC;
             border: #000 1px solid;
            float:left;
             font-size: 17px;
             font-family:Roman;
         }
         
         div .mini{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         div .mini01{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
    </style>
   <script type="text/javascript">
      $(function () {
                // <input type="button" value=" 改變第一個 div 元素的背景色爲 粉色"  id="b1"/>
            $("#b1").click(function () {
                $("div:first").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變最後一個 div 元素的背景色爲 粉色"  id="b2"/>
            $("#b2").click(function () {
                $("div:last").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變class不爲 one 的所有 div 元素的背景色爲 粉色"  id="b3"/>
            $("#b3").click(function () {
                $("div:not(.one)").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變索引值爲偶數的 div 元素的背景色爲 粉色"  id="b4"/>
            $("#b4").click(function () {
                $("div:even").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變索引值爲奇數的 div 元素的背景色爲 粉色"  id="b5"/>
            $("#b5").click(function () {
                $("div:odd").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變索引值爲大於 3 的 div 元素的背景色爲 粉色"  id="b6"/>
            $("#b6").click(function () {
                $("div:gt(3)").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變索引值爲等於 3 的 div 元素的背景色爲 粉色"  id="b7"/>
            $("#b7").click(function () {
                $("div:eq(3)").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變索引值爲小於 3 的 div 元素的背景色爲 粉色"  id="b8"/>
            $("#b8").click(function () {
                $("div:lt(3)").css("backgroundColor","pink");
            })
                // <input type="button" value=" 改變所有的標題元素的背景色爲 粉色"  id="b9"/>
            $("#b9").click(function () {
                $(":header").css("backgroundColor","pink");
            })
        })
   </script>
   </head>


   <body>
            
       <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
       <input type="button" value=" 改變第一個 div 元素的背景色爲 粉色"  id="b1"/>
       <input type="button" value=" 改變最後一個 div 元素的背景色爲 粉色"  id="b2"/>
       <input type="button" value=" 改變class不爲 one 的所有 div 元素的背景色爲 粉色"  id="b3"/>
       <input type="button" value=" 改變索引值爲偶數的 div 元素的背景色爲 粉色"  id="b4"/>
       <input type="button" value=" 改變索引值爲奇數的 div 元素的背景色爲 粉色"  id="b5"/>
       <input type="button" value=" 改變索引值爲大於 3 的 div 元素的背景色爲 粉色"  id="b6"/>
       <input type="button" value=" 改變索引值爲等於 3 的 div 元素的背景色爲 粉色"  id="b7"/>
       <input type="button" value=" 改變索引值爲小於 3 的 div 元素的背景色爲 粉色"  id="b8"/>
       <input type="button" value=" 改變所有的標題元素的背景色爲 粉色"  id="b9"/>
       
      
       <h1>有一種奇蹟叫堅持</h1>
       <h2>自信源於努力</h2>
       
        <div id="one">
           id爲one  
           
       </div>
      
       <div id="two" class="mini" >
             id爲two   class是 mini
             <div  class="mini" >class是 mini</div>
      </div>
      
       <div class="one" >
             class是 one
             <div  class="mini" >class是 mini</div>
            <div  class="mini" >class是 mini</div>
       </div>
       <div class="one" >
           class是 one
             <div  class="mini01" >class是 mini01</div>
            <div  class="mini" >class是 mini</div>
      </div>
   </body>
</html>

運行結果:

點擊按鈕一

點擊按鈕二

點擊按鈕三

點擊按鈕四

點擊按鈕五

點擊按鈕六

點擊按鈕七

點擊按鈕八

點擊按鈕九

        5. 表單過濾選擇器

            1. 可用元素選擇器

                * 語法: :enabled 獲得可用元素

            2. 不可用元素選擇器

                * 語法: :disabled 獲得不可用元素

            3. 選中選擇器

                * 語法: :checked 獲得單選/複選框選中的元素

            4. 選中選擇器

                * 語法: :selected 獲得下拉框選中的元素

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>表單屬性過濾選擇器</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   <script  src="../js/jquery-3.3.1.min.js"></script>
   <style type="text/css">
         div,span{
             width: 180px;
             height: 180px;
             margin: 20px;
             background: #9999CC;
             border: #000 1px solid;
            float:left;
             font-size: 17px;
             font-family:Roman;
         }
         
         div .mini{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         
         div .mini01{
             width: 50px;
             height: 50px;
             background: #CC66FF;
             border: #000 1px solid;
             font-size: 12px;
             font-family:Roman;
         }
         #job{
            margin: 20px;
         }
         #edu{
            margin-top:-70px;
         }
         
    </style>
    <script type="text/javascript">
       $(function () {
                // <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內可用 <input> 元素的值"  id="b1"/>
            $("#b1").click(function () {
                $("input[type='text']:enabled").val("aaaaaaaa");
            });
                // <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內不可用 <input> 元素的值"  id="b2"/>
            $("#b2").click(function () {
                $("input[type='text']:disabled").val("bbbbbbb");
            });
                // <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取複選框選中的個數"  id="b3"/>
            $("#b3").click(function () {
                alert($("input[type='checkbox']:checked").length);
            });
                // <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取下拉框選中的個數"  id="b4"/>
            $("#b4").click(function () {
                alert($("#job>option:selected").length);
            });
        })
      
   
   
   </script>
   </head>
    
   <body>
            
       <input type="button" value="保存"  class="mini" name="ok"  class="mini" />
       <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內可用 <input> 元素的值"  id="b1"/>
       <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內不可用 <input> 元素的值"  id="b2"/>
       <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取複選框選中的個數"  id="b3"/>
       <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取下拉框選中的個數"  id="b4"/>
      

      
         <input type="text" value="不可用值1" disabled="disabled">
       <input type="text" value="可用值1" >
       <input type="text" value="不可用值2" disabled="disabled">
       <input type="text" value="可用值2" >
       
       

       <input type="checkbox" name="items" value="美容" >美容
       <input type="checkbox" name="items" value="IT" >IT
       <input type="checkbox" name="items" value="金融" >金融
       <input type="checkbox" name="items" value="管理" >管理
       
       

       
        <input type="radio" name="sex" value="男" >男
        <input type="radio" name="sex" value="女" >女
        
         

       
        <select name="job" id="job" multiple="multiple" size=4>
           <option>程序員</option>
         <option>中級程序員</option>
         <option>高級程序員</option>
         <option>系統分析師</option>
          </select>
          
          <select name="edu" id="edu">
           <option>本科</option>
         <option>博士</option>
         <option>碩士</option>
         <option>大專</option>
          </select>
      
         
      <br/>
         
       <div id="two" class="mini" >
             id爲two   class是 mini  div
             <div  class="mini" >class是 mini</div>
      </div>
      
       <div class="one" >
             class是 one
             <div  class="mini" >class是 mini</div>
            <div  class="mini" >class是 mini</div>
       </div>
       <div class="one" >
           class是 one
             <div  class="mini01" >class是 mini01</div>
            <div  class="mini" >class是 mini</div>
      </div>
      
   </body>
</html>

運行結果:

點擊按鈕一

點擊按鈕二

點擊按鈕三

點擊按鈕四

 

掌握以上選擇器就差不多能滿足平時需求了,如果還想了解更多可以查看API文檔。

國內在線JQuery API:http://jquery.cuishifeng.cn/

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章