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/

 

 

 

 

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