jQuery 元素筛选
就是把前面的一些选择器变成了方法,效果是一样的。
过滤:
- eq() 获取给定索引的元素 功能跟 :eq() 一样
- first() 获取第一个元素 功能跟 :first 一样
- last() 获取最后一个元素 功能跟 :last 一样
- filter(exp) 留下匹配的元素
- is(exp) 判断是否匹配给定的选择器,只要有一个匹配就返回,true
- has(exp) 返回包含有匹配选择器的元素的元素 功能跟 :has 一样
- not(exp) 删除匹配选择器的元素 功能跟 :not 一样
查找:
- children(exp) 返回匹配给定选择器的子元素,仅限于儿子元素。功能跟 parent>child 一样
- find(exp) 返回匹配给定选择器的后代所有元素(儿子、孙子……)。功能跟 ancestor descendant 一样
- next() 返回当前元素的下一个兄弟元素 功能跟 prev + next 功能一样
- nextAll() 返回当前元素后面所有的兄弟元素 功能跟 prev ~ siblings 功能一样
- nextUntil() 返回当前元素到指定匹配的元素为止的后面元素 ,左闭右开区间,不包括Until里面的元素
- parent() 返回父元素
- prev(exp) 返回当前元素的上一个兄弟元素
- prevAll() 返回当前元素前面所有的兄弟元素
- prevUnit(exp) 返回当前元素到指定匹配的元素为止的前面元素
- siblings(exp) 返回所有兄弟元素
串联:
- 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>