jQuery(三)——jQuery 元素筛选

jQuery 元素筛选

就是把前面的一些选择器变成了方法,效果是一样的。

过滤:

  1. eq() 获取给定索引的元素 功能跟 :eq() 一样
  2. first() 获取第一个元素 功能跟 :first 一样
  3. last() 获取最后一个元素 功能跟 :last 一样
  4. filter(exp) 留下匹配的元素
  5. is(exp) 判断是否匹配给定的选择器,只要有一个匹配就返回,true
  6. has(exp) 返回包含有匹配选择器的元素的元素 功能跟 :has 一样
  7. not(exp) 删除匹配选择器的元素 功能跟 :not 一样

查找:

  1. children(exp) 返回匹配给定选择器的子元素,仅限于儿子元素。功能跟 parent>child 一样
  2. find(exp) 返回匹配给定选择器的后代所有元素(儿子、孙子……)。功能跟 ancestor descendant 一样
  3. next() 返回当前元素的下一个兄弟元素 功能跟 prev + next 功能一样
  4. nextAll() 返回当前元素后面所有的兄弟元素 功能跟 prev ~ siblings 功能一样
  5. nextUntil() 返回当前元素到指定匹配的元素为止的后面元素 ,左闭右开区间,不包括Until里面的元素
  6. parent() 返回父元素
  7. prev(exp) 返回当前元素的上一个兄弟元素
  8. prevAll() 返回当前元素前面所有的兄弟元素
  9. prevUnit(exp) 返回当前元素到指定匹配的元素为止的前面元素
  10. siblings(exp) 返回所有兄弟元素

串联:

  1. add() 把 add 匹配的选择器的元素添加到当前 jquery 对象中

is筛选举例

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>jQuery-2021-01-30</title>
    <style type="text/css">
        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: 12px;
        }

        div.hide {
     
     
            display: none;
        }
    </style>

    <script type="text/javascript" src="../script/jquery-1.7.2.js"></script>
    <script type="text/javascript">
    //(1)eq() 选择索引值为等于 3 的 div 元素
    //(2)first()选择第一个 div 元素
    //(3)last()选择最后一个 div 元素
    //(4)filter()在div中选择索引为偶数的
    //(5)is()判断#one是否为:empty或:parent
    //(6)has()选择div中包含.mini的
    //(7)not()选择div中class不为one的
    //(8)children()在body中选择所有class为one的div子元素
    //(9)find()在body中选择所有class为mini的div元素
    //(10)next() #one的下一个div
    //(11)nextAll() #one后面所有的span元素
    //(12)nextUntil() #one和span之间的元素
    //(13)parent() .mini的父元素
    //(14)prev() #two的上一个div
    //(15)prevAll() span前面所有的div
    //(16)prevUntil() span向前直到#one的元素
    //(17)siblings() #two的所有兄弟元素
    //(18)add()选择所有的 span 元素和id为two的元素
    </script>

</head>
<body>
<input type="button" value="eq()选择索引值为等于 3 的 div 元素" id="btn1" />
<input type="button" value="first()选择第一个 div 元素" id="btn2" />
<input type="button" value="last()选择最后一个 div 元素" id="btn3" />
<input type="button" value="filter()在div中选择索引为偶数的" id="btn4" />
<input type="button" value="is()判断#one是否为:empty或:parent" id="btn5" />
<input type="button" value="has()选择div中包含.mini的" id="btn6" />
<input type="button" value="not()选择div中class不为one的" id="btn7" />
<input type="button" value="children()在body中选择所有class为one的div子元素" id="btn8" />
<input type="button" value="find()在body中选择所有class为mini的div后代元素" id="btn9" />
<input type="button" value="next()#one的下一个div" id="btn10" />
<input type="button" value="nextAll()#one后面所有的span元素" id="btn11" />
<input type="button" value="nextUntil()#one和span之间的元素" id="btn12" />
<input type="button" value="parent().mini的父元素" id="btn13" />
<input type="button" value="prev()#two的上一个div" id="btn14" />
<input type="button" value="prevAll()span前面所有的div" id="btn15" />
<input type="button" value="prevUntil()span向前直到#one的元素" id="btn16" />
<input type="button" value="siblings()#two的所有兄弟元素" id="btn17" />
<input type="button" value="add()选择所有的 span 元素和id为two的元素" id="btn18" />


<h3>基本选择器.</h3>
<br /><br />
文本框<input type="text" name="account" disabled="disabled" />
<br><br>
<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"><b>class为mini,title为other</b></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>
<span id="span1">^^span元素 111^^</span>
<div>
    包含input的type为"hidden"的div<input type="hidden" size="8">
</div>
<span id="span2">^^span元素 222^^</span>
</body>
</html>

界面效果如图所示:
在这里插入图片描述
功能实现:

    <script type="text/javascript" src="../script/jquery-1.7.2.js"></script>
    <script type="text/javascript">
        $(function () {
     
     
            //(1)eq() 选择索引值为等于 3 的 div 元素
            $("#btn1").click(function () {
     
     
                $("div").eq(3).css("background","red");
            });
            //(2)first()选择第一个 div 元素
            $("#btn2").click(function () {
     
     
                $("div").first().css("background","red");
            });
            //(3)last()选择最后一个 div 元素
            $("#btn3").click(function () {
     
     
                $("div").last().css("background","red");
            });
            //(4)filter()在div中选择索引为偶数的
            $("#btn4").click(function () {
     
     
                //filter()  过滤,传入的是选择器字符串
                $("div").filter(":even").css("background","red");
            });
            //(5)is()判断#one是否为:empty或:parent
            $("#btn5").click(function () {
     
     
                alert("是否空:"+$("#one").is(":empty"));  //空的话返回true
                alert("是否非空:"+$("#one").is(":parent"));  //非空的返回true
            });
            //(6)has()选择div中包含.mini的
            $("#btn6").click(function () {
     
     
                $("div").has(".mini").css("background","red");
                //$("div:has(.mini)").css("background","red");
            });    //二者做一下对比
            //(7)not()选择div中class不为one的
            $("#btn7").click(function () {
     
     
                $("div").not(".one").css("background","red");
                //$("div:not(.one)").css("background","red");
            });
            //(8)children() 在body中选择所有class为one的div子元素
            $("#btn8").click(function () {
     
     
                $("body").children("div.one").css("background","red");
                //$("body > div.one").css("background","red");
            });
            //(9)find()在body中选择所有class为mini的div元素
            $("#btn9").click(function () {
     
     
                $("body").find("div.mini").css("background","red");
                //$("body div.mini").css("background","red");
            });
            //(10)next() #one的下一个兄弟div元素
            $("#btn10").click(function () {
     
     
                $("#one").next("div").css("background","red");
                //$("#one + div").css("background","red");
            });
            //(11)nextAll() #one后面所有的span兄弟元素
            $("#btn11").click(function () {
     
     
                $("#one").nextAll("span").css("background","red");
                //$("#one ~ span").css("background","red");
            });
            //(12)nextUntil() #one和span之间的元素
            $("#btn12").click(function () {
     
     
                $("#one").nextUntil("span").css("background","red");
            });
            //(13)parent() .mini的父元素
            $("#btn13").click(function () {
     
     
                $(".mini").parent().css("background","red");
            });
            //(14)prev() #two的上一个div(同级兄弟元素)
            $("#btn14").click(function () {
     
     
                $("#two").prev("div").css("background","red");
            });
            //(15)prevAll() span前面所有的div(同级兄弟元素)
            $("#btn15").click(function () {
     
     
                $("span").prevAll("div").css("background","red");
            });
            //(16)prevUntil() span向前直到#one的元素(同级兄弟元素)
            $("#btn16").click(function () {
     
     
                $("span").prevUntil("#one").css("background","red");
            });
            //(17)siblings() #two的所有兄弟元素
            $("#btn17").click(function () {
     
     
                $("#two").siblings().css("background","red");
                //$("#two").siblings("div").css("background","red");
            });        //设置参数,得到所有和id为two的div兄弟元素
            //(18)add()选择所有的 span 元素和id为two的元素
            $("#btn18").click(function () {
     
     
                $("span").add("#two").css("background","red");
                //$("span").add("#two").add("#one").css("background","red");
                                   //可以一直通过add累加
                $("span,#two").css("background","red"); //同一个效果
            });   //注意对比 $(div.class01)   $(div#id01)和上述的区别
        });
    </script>

猜你喜欢

转载自blog.csdn.net/HangHug_L/article/details/113446648