锋利的jQuery读书笔记---选择器

前段时间入手了锋利的jQuery(第二版),想着加强下自己的js能力,可前段时间一只在熟悉Spring和Hibernate。最近抽时间开始读这本书了,随便也做了些记录。

读书的过程是边看边代码测试,所以笔记和代码也就写到一起了。下面是选择器的记录:

<!DOCTYPE html>
<html>
<head lang="zh">
    <meta charset="UTF-8">
    <script type="text/javascript" src="../js/jquery-2.1.3.js"></script>

    <title></title>

    <style>

        div, span, p{
            width: 140px;
            height: 140px;
            margin: 5px;
            background: #aaa;
            border: #000 1px solid;
            float: left;
            font-size: 17px;
            font-family: Verdana;
        }

        div.mini {
            width: 55px;
            height: 55px;
            background-color: #aaa;
            font-size: 10px;
        }

        div.hide {
            display: none;
        }

    </style>

</head>
<body>

<h1>jQuery选择器</h1>

<div class="one" id="one">
    id为one, class为one的div
    <div class="mini">class为mini</div>
</div>

<div class="one" id="two" title="test">
    id为two, class为one, title为test的div
    <div class="mini" title="other">class为mini, title为other</div>
    <div class="mini" title="test">class为mini, title为test</div>
</div>

<div class="one">
    <div class="mini">class为mini</div>
    <div class="mini">class为mini</div>
    <div class="mini">class为mini</div>
    <div class="mini"></div>
</div>

<div class="one">
    <div class="mini">class为mini</div>
    <div class="mini">class为mini</div>
    <div class="mini">class为mini</div>
    <div class="mini" title="tesst">class为mini, title为tesst</div>
</div>

<div style="display:none;" class="none">
    style的display为"none"的div
</div>

<div class="hide">class为hide的div</div>

<div>
    包含input的type为"hidden"的div<input type="hidden" size="8" />
</div>

<span id="mover">正在执行动画的span元素.</span>

<br/><br/><br/><br/><br/><br/><br/><br/>
<hr/>

<div title="en">title为en的div元素</div>
<div title="en-UK">title为en-UK的div元素</div>
<div title="english">title为english的div元素</div>
<div title="en uk">title为en uk的div元素</div>
<div title="uken">title为uken的div元素</div>

<br/><br/><br/><br/><br/><br/><br/><br/>
<hr/>

<form id="form1" action="#">
    可用元素: <input name="add" value="可用文本框" /> <br/>
    不可用元素: <input name="email" disabled="disabled" value="不可用文本框" /> <br/>
    可用元素: <input name="che" value="可用文本框" /> <br/>
    不可用元素: <input name="name" disabled="disabled" value="不可用文本框" /> <br/>
    <br/>
    多选框: <br/>
    <input type="checkbox" name="newsletter" checked="checked" value="test1" />test1
    <input type="checkbox" name="newsletter" value="test2" />test2
    <input type="checkbox" name="newsletter" value="test3" />test3
    <input type="checkbox" name="newsletter" checked="checked" value="test4" />test4
    <input type="checkbox" name="newsletter" value="test5" />test5
    <br/><br/>
    下拉列表1: <br/>
    <select name="test" multiple="multiple" style="height: 100px">
        <option>浙江</option>
        <option selected="selected">湖南</option>
        <option>北京</option>
        <option selected="selected">天津</option>
        <option>广州</option>
        <option>湖北</option>
    </select>
    <br/><br/>
    下拉列表2: <br/>
    <select name="test2">
        <option>浙江</option>
        <option>湖南</option>
        <option selected="selected">北京</option>
        <option>天津</option>
        <option>广州</option>
        <option>湖北</option>
    </select>
</form>


</body>

<script type="text/javascript">

   /**
   * 1.基本选择器
    *
    *       #id         根据给定的id匹配一个元素         返回单个元素     $("#test")选取id为test的元素
    *       .class      根据给定的类名匹配元素           返回集合元素     $(".test")选取所有class为test的元素
    *       element     根据给定的元素名匹配元素         返回集合元素     $("p")选取所有的<p>元素
    *       *           匹配所有的元素                  返回集合元素     $("*")选取所有的元素
    *       selector1,
    *       selector2,  将每一个选择器匹配的元素         返回集合元素     $("div, span, p.myClass")选取所有<div>,
    *       ......,     合并后一起返回                                 <span>和拥有class为myClass的<p>标签的一组元素
    *       selectorN
   * */
    //改变id为one的元素的背景色
    //$("#one").css("background", "#bbffaa");

    //改变class为mini的所有元素的背景色
    //$(".mini").css("background", "#bbffaa");

    //改变元素名称是<div>的所有元素的背景色
    //$("div").css("background", "#bbffaa");

    //改变所有元素的背景色
    //$("*").css("background", "#bbffaa");

    //改变所有span元素和id为two的元素的背景色
    //$("span, #two").css("background", "#bbffaa");

    /**
    * 2.层次选择器
     *
     *      $("ancestor descendant")    选取ancestor元素里的所有descendant(后代)元素        返回集合元素      $("div span")选取<div>里所有的<span>元素
     *      $("parent > child")         选取patent元素下的child(子)元素                    返回集合元素      $("div > span")选取<div>元素下元素名是<span>的子元素
     *      $("prev + next")            选取紧接在prev元素后的next元素                     返回集合元素      $(".one + div")选取class为one的下一个<div>元素
     *      $("prev ~ siblings")        选取prev元素之后的所有siblings元素                 返回集合元素      $("#two ~ div")选取id为two的元素后面的所有<div>同辈元素
    * */
    //改变body内所有div的背景色---可以包括多层继承关系
    //$("body div").css("background", "#bbffaa");

    //改变body内子div元素的背景色----仅包括一层继承关系
    //$("body > div").css("background", "#bbffaa");

    //改变class为one的下一个div同辈元素的背景色
    //$(".one + div").css("background", "#bbffaa");

    //改变id为two的元素后面的所有div同辈元素的背景色
    //$("#two ~ div").css("background", "#bbffaa");

    /**
     * 总结:在层次选择器中,第1和第2个选择器比较常用,而后面的两个因为在jQuery里可以使用更加简单的方法替代,所以使用几率较小。
     *
     * 1.可以使用next()方法来代替$("prev + next")选择器----即$(".one + div") == $(".one").next("div")
     * 2.可以使用nextAll()方法来代替$("prev ~ siblings")选择器----即$(".one ~ div") == $(".one").nextAll("div")
     *
     *
     * tips:
     *  siblings()方法与$("prev ~ siblings")选择器的比较:
     *      $("#prev ~ div")选择器只能选择"prev"元素后面的同辈<div>元素
     *      而siblings()方法与前后位置无关,只要是同辈节点都能匹配
     * */


    /**
     * 3.过滤选择器
     *
     *  过滤选择器主要是通过特定的过滤规则来筛选出所需的DOM元素,过滤规则与CSS中的伪类选择器语法相同,即选择器都以冒号(:)开头。
     *  按照不同的过滤规则,过滤选择器可以分为基本过滤器、内容过滤器、可见性过滤器、属性过滤器、子元素过滤器和表单对象属性过滤器
     * */

    /**
     * 3.1.基本过滤器
     *      :first          选取第一个元素                          返回单个元素       $("div:first")选取所有<div>元素中第1个<div>元素
     *      :last           选取最后一个元素                        返回单个元素       $("div:last")选取所有<div>元素中最后一个<div>元素
     *      :not(selector)  去除所有与给定选择器匹配的元素            返回集合元素       $("input:not(.myClass)")选取class不是myClass的<input>元素
     *      :even           选取索引是偶数的所有元素,索引从0开始      返回集合元素       $("input:even")选取索引是偶数的<input>元素
     *      :odd            选取索引是奇数的所有元素,索引从0开始      返回集合元素       $("input:odd")选取索引是奇数的<input>元素
     *      :eq(index)      选取索引等于index的元素,索引从0开始      返回单个元素       $("input:eq(1)")选取索引等于1的<input>元素
     *      :gt(index)      选取索引大于index的元素,索引从0开始      返回集合元素       $("input:gq(1)")选取索引大于1的<input>元素(大于1,不包括1)
     *      :lt(index)      选取索引小于index的元素,索引从0开始      返回集合元素       $("input:lq(1)")选取索引小于1的<input>元素(小于1,不包括1)
     *      :header         选取所有的标题元素,例如h1,h2等          返回集合元素       $(":header")选取网页中所有的<h1>,<h2>,<h3>......
     *      :animated       选取当前正在执行动画的元素               返回集合元素        $("div:animated")选取正在执行动画的<div>元素
     *      :focus          选取当前获取焦点的元素                   返回集合元素        $(":focus")选取当前获取焦点的元素
     * */
    //改变第1个<div>元素的背景色
    //$("div:first").css("background", "#bbffaa");

    //改变最后一个<div>元素的背景色
    //$("div:last").css("background", "#bbffaa");

    //改变class不为one的<div>元素的背景色
    //$("div:not(.one)").css("background", "#bbffaa");

    //改变索引值为偶数的<div>元素的背景色
    //$("div:even").css("background", "#bbffaa");

    //改变索引值为奇数的<div>元素的背景色
    //$("div:odd").css("background", "#bbffaa");

    //改变索引值等于3的<div>元素的背景色
    //$("div:eq(3)").css("background", "#bbffaa");

    //改变索引值大于3的<div>元素的背景色
    //$("div:gt(3)").css("background", "#bbffaa");

    //改变索引值小于3的<div>元素的背景色
    //$("div:lt(3)").css("background", "#bbffaa");

    //改变所有标题元素,例如<h1>,<h2>,<h3>......这些元素的背景色
    //$(":header").css("background", "#bbffaa");

    //改变当前正在执行动画的元素的背景色
    //$(":animated").css("background", "#bbffaa");

    //改变当前获取焦点的元素的背景色
    //$(":focus").css("background", "#bbffaa");


    /**
     * 3.2.内容过滤器
     *
     *      :contains(text)     选取含有文本内容为"text"的元素      返回集合元素     $("div:contains(‘我‘)")选取含有文本"我"的<div>元素
     *      :empty              选取不包含子元素或文本的空元素       返回集合元素     $("div:empty")选取不包含子元素(包括文本元素)的<div>元素
     *      :has(selector)      选取含有选择器所匹配的元素的元素     返回集合元素     $("div:has(p)")选取含有<p>元素的<div>元素
     *      :parent             选取含有子元素或者文本的元素        返回集合元素     $("div:parent")选取拥有子元素(包括文本元素)的<div>元素
     * */

    //改变含有文本"di"的<div>元素的背景色
    //$("div:contains(di)").css("background", "#bbffaa");

    //改变不包含子元素(包括文本元素)的<div>空元素的背景色
    //$("div:empty").css("background", "#bbffaa");

    //改变含有class为mini元素的<div>元素的背景色
    //$("div:has(.mini)").css("background", "#bbffaa");

    //改变含有子元素(包括文本元素)的<div>元素的背景色
    //$("div:parent").css("background", "#bbffaa");


    /**
     * 3.3.可见性过滤选择器
     *
     *      :hidden     选取所有不可见的元素      返回集合元素      $(":hidden")选取所有不可见的元素。包括<input type="hidden" />, <div style="display:none;">和<div style="visibility:hidden;">等元素。如果指向选取<input>元素,可以使用$("input:hidden")
     *      :visible    选取所有可见的元素       返回集合元素       $("div:visible")选取所有可见的<div>元素
     * */

    //改变所有可见的<div>元素的背景色
    //$("div:visible").css("background", "#bbffaa");

    //显示隐藏的<div>元素
    //$("div:hidden").show(3000);


    /**
     * 3.4.属性过滤选择器
     *
     *      [attribute]                 选取拥有此属性的元素                                返回集合元素      $("div[id]")选取拥有属性id的<div>元素
     *      [attribute=value]           选取属性的值为value的元素                           返回集合元素      $("div[title=test]")选取属性title为"test"的<div>元素
     *      [attribute!=value]          选取属性的值不等于value的元素                       返回集合元素       $("div[title!=test]")选取属性title不等于"test"的<div>元素(注意:没有属性title的<div>元素也会被选取)
     *      [attribute^=value]          选取属性的值以value开始的元素                       返回集合元素      $("div[title^=test]")选取属性title以"test"开始的<div>元素
     *      [attribute$=value]          选取属性的值以value结束的元素                       返回集合元素      $("div[title$=test]")选取属性title以"test"结束的<div>元素
     *      [attribute*=value]          选取属性的值含有value的元素                        返回集合元素      $("div[title*=test]")选取属性title含有"test"的<div>元素
     *      [attribute|=value]          选取属性等于给定的字符串或以该字符串为前缀的元素      返回集合元素      $("div[title|=‘en‘]")选取属性title等于en或以en为前缀(该字符串后跟一个连字符‘_‘)的<div>元素
     *      [attribute~=value]          选取属性用空格分隔的值中包含一个给定的值的元素        返回集合元素      $("div[title~=‘uk‘]")选取属性title用空格分隔的值中包含uk的<div>元素
     *      [attribute1][attribute2]    用属性选择器合并成一个复合属性选择器,满足多个条件。   返回集合元素      $("div[id][title$=‘test‘]")选取拥有属性id,并且属性title以"test"结束的<div>元素
     *      [attributeN]                每选择一次,缩小一次范围。
     * */

    //改变含有属性title的<div>的背景色
    //$("div[title]").css("background", "#bbffaa");

    //改变属性title值等于"test"的<div>元素的背景色
    //$("div[title=test]").css("background", "#bbffaa");

    //改变属性title值不等于"test"的<div>元素的背景色
    //$("div[title!=test]").css("background", "#bbffaa");

    //改变属性title值以"te"开始的<div>元素的背景色
    //$("div[title^=te]").css("background", "#bbffaa");

    //改变属性title值以"est"结束的<div>元素的背景色
    //$("div[title$=est]").css("background", "#bbffaa");

    //改变属性title值含有"es"的<div>元素的背景色
    //$("div[title*=es]").css("background", "#bbffaa");

    //改变含有属性id,并且属性title值含有"es"的<div>元素的背景色
    //$("div[id][title*=es]").css("background", "#bbffaa");

    //改变属性title值以"en"开始的<div>元素的背景色
    //$("div[title^=en]").css("background", "#bbffaa");

    //改变属性title值包含"en"的<div>元素的背景色
    //$("div[title*=en]").css("background", "#bbffaa");

    //改变属性title值以"en"结束的<div>元素的背景色
    //$("div[title$=en]").css("background", "#bbffaa");

    //改变属性title值等于"en"或以"en"为前缀(该字符串后跟一个连字符‘_‘)<div>元素的背景色
    //$("div[title|=en]").css("background", "#bbffaa");

    //改变属性title用空格分隔的值中包含字符"uk"的<div>元素的背景色
    //$("div[title~=uk]").css("background", "#bbffaa");


    /**
     * 3.5.子元素过滤选择器
     *
     *      :nth-child(index/even/odd/equation)     选取每个父元素下的第index个子元素或者奇偶元素(index从1算起)        返回集合元素      :eq(index)只匹配一个元素,而:nth-child将为每个父元素匹配子元素,并且:nth-child(index)的index是从1开始的,而:eq(index)是从0开始的
     *      :first-child                            选取每个父元素的第1个子元素                                      返回集合元素      :first只返回单个元素,而:first-child选择符将为每个父元素匹配第1个子元素。例如$("ul li:first-child")选取每个<ul>中第1个<li>元素
     *      :last-child                             选取每个父元素的最后1个子元素                                    返回集合元素      :last只返回单个元素,而:last-child选择符将为每个父元素匹配最后1个子元素。例如$("ul li:last-child")选取每个<ul>中最后1个<li>元素
     *      :only-child                             如果某个元素是它父元素中唯一的子元素,那么将会被匹配。              返回集合元素      $("ul li:only-child")在<ul>中选取唯一子元素的<li>元素
     *                                              如果父元素中含有其他元素,则不会被匹配。
     *
     *  --------------------------------------------------------------------------------------------------------------------------------------------------------
     *      :nth-child()选择器是很常用的子元素过滤选择器,详细功能如下:
     *      1.:nth-child(even)能选取每个父元素下的索引值是偶数的元素
     *      2.:nth-child(odd)能选取每个父元素下的索引值是奇数的元素
     *      3.:nth-child(2)能选取每个父元素下的索引值等于2的元素
     *      4.:nth-child(3n)能选取每个父元素下的索引值是3的倍数的元素(n从1开始)
     *      5.:nth-child(3n+1)能选取每个父元素下的索引值是(3n+1)的元素(n从1开始)
     * */

    //改变每个class为one的<div>父元素下的第2个子元素的背景色
    //$("div.one :nth-child(2)").css("background", "#bbffaa");

    //改变每个class为one的<div>父元素下的第一个子元素的背景色
    //$("div.one :first-child").css("background", "#bbffaa");

    //改变每个class为one的<div>父元素下的最后一个子元素的背景色
    //$("div.one :last-child").css("background", "#bbffaa");

    //如果class为one的<div>父元素下只有一个子元素,那么则改变这个子元素的背景色
    //$("div.one :only-child").css("background", "#bbffaa");


    /**
     * 3.6.表单对象属性过滤选择器
     *
     *      :enabled        选取所有可用的元素                   返回集合元素      $("#form1 :enabled")选取id为form1的表单内所有可用的元素
     *      :disabled       选取所有不可用的元素                 返回集合元素      $("#form1 :disabled")选取id为form1的表单内所有不可用的元素
     *      :checked        选取所有被选中的元素(单选框,复选框)   返回集合元素      $("input:checked")选取所有被选中的<input>元素
     *      :selected       选取所有被选中的选项元素(下拉列表)     返回集合元素      $("select option :selected")选取所有被选中的选项元素
     *
     * */

    //改变表单内可用的<input>元素的值
    //$("#form1 input:enabled").val("这里变化了!");

    //改变表单内不可用<input>元素的值
    //$("#form1 input:disabled").val("这里变化了!");

    //获取多选框选中的个数
    //$("input :checked").length;

    //获取下拉选择框选中的内容
    //$("select :selected").text();


    /**
     * 表单选择器
     *  为了使用户能够更加灵活的操作表单,jQuery中专门加入了表单选择器。利用这个选择器,能及其方便地获取到表单的某个或某类型的元素
     *
     *  :input      选取所有的<input>、<textarea>、<select>和<button>元素     返回集合元素     $(":input")选取所有<input>、<textarea>、<select>和<button>元素
     *  :text       选取所有的单行文本框                                      返回集合元素     $(":text")选取所有的单行文本框
     *  :password   选取所有的密码框                                          返回集合元素    $(":password")选取所有的密码框
     *  :radio      选取所有的单选框                                          返回集合元素    $(":radio")选取所有的单选框
     *  :checkbox   选取所有的多选框                                          返回集合元素    $(":checkbox")选取所有的多选框
     *  :submit     选取所有的提交按钮                                        返回集合元素     $(":submit")选取所有的提交按钮
     *  :image      选取所有的图像按钮                                        返回集合元素     $(":image")选取所有的图像按钮
     *  :reset      选取所有的重置按钮                                        返回集合元素     $(":reset")选取所有的重置按钮
     *  :button     选取所有的按钮                                            返回集合元素     $(":button")选取所有的按钮
     *  :file       选取所有的上传域                                          返回集合元素     $(":file")选取所有的上传域
     *  :hidden     选取所有不可见元素                                        返回集合元素     $(":hidden")选取所有不可见的元素
     *
     *
     * */

</script>

</html>

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。