学习前端也有一段时间了,今天终于进入到JQuery阶段了,对于新手来讲,JQuery的选择器类型之多 功能之强大实在不是一天两天能够记得完的。现在,就采用边学边记录的方式。以后要是忘了的话,也有一个地方能够迅速找到。今天也是站在前辈大神的肩膀上学习JQuery。
1.属性选择器
属性选择器的语法
jQuery( "[attribute|='value']" ) attribute: 一个属性名. value: 一个属性值,引号是可选的. 可以是一个不带引号的一个单词或带一个引号的字符串。
实例:
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="../js/jquery-2.1.1.min.js"></script>
<!--<script src="../js/selector.js"></script>-->
<style>
a{
display: block; }
</style>
</head>
<body>
<a href="#" hreflang="en">Some text</a>
<a href="#" hreflang="en-UK">Some other text</a>
<a href="#" hreflang="english">will not be outlined</a>
<script> $("a[hreflang = 'en']").css("background","red");
$("a[hreflang |='en']").css("border","1px solid red");
</script>
</body>
</html>
和CSS选择器一样 属性选择器也有多种多样的根据属性值查找元素的写法。下图就是不同的查找属性值的选择器写法
2.基础选择器
2.1 all Selector
选择所有的元素
语法
jQuery( "*" )
注意:除非被它自己使用,否则"*"选择器或通用选择器,其速度是极慢的。
例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="../js/jquery-2.1.1.min.js"></script>
<style type="text/css">
div,span,p {
width: 80px;
text-align: center;
height: 40px;
float: left;
margin: 15px;
padding: 10px;
background-color: #eeeeee;
}
</style>
</head>
<body>
<div>DIV</div>
<span>SPAN</span>
<p>P <button>Button</button></p>
<script>
var elements = $("*").css("border","1px solid red").length;
$("body").prepend("<h3>"+ elements + "elements found</h3>")
</script> </body>
</html>
效果:
查找一个DIV中的所有元素
<!DOCTYPE html>
<html>
<head>
<style>
h3 { margin: 0; }
div,span,p {
width: 80px;
height: 40px;
float:left;
padding: 10px;
margin: 10px;
background-color: #EEEEEE;
}
#test {
width: auto; height: auto; background-color: transparent;
}
</style>
<script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
</head>
<body>
<div id="test">
<div>DIV</div>
<span>SPAN</span>
<p>P <button>Button</button></p>
</div>
<script>
var elementCount = $("#test").find("*").css("border","3px solid red").length;
$("body").prepend("<h3>" + elementCount + " elements found</h3>");</script> </body>
</html>
效果图
2.2 类选择器
选择给定样式类名的所有元素
语法:
jQuery( ".class" )
class: 一个用来查找的类名。一个元素可以有多个类;其中只有一个必须匹配
对于类选择器,如果浏览器支持,jQuery使用JavaScript的原生getElementsByClassName()函数来实现。
例子:
<!DOCTYPE html>
<html>
<head>
<style>
div,span {
width: 100px;
height: 40px;
float:left;
padding: 10px;
margin: 10px;
background-color: #EEEEEE;
}
</style>
<script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
</head>
<body>
<div class="notMe">div class="notMe"</div> <div class="myClass">div class="myClass"</div>
<span class="myClass">span class="myClass"</span>
<script>$(".myClass").css("border","3px solid red");</script> </body>
</html>
效果图
查找的元素都“的myclass”和“otherclass的的”类。
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="../js/jquery-2.1.1.min.js"></script>
<style type="text/css">
div,span,p {
width: 120px;
text-align: center;
height: 40px;
float: left;
margin: 15px;
padding: 10px;
background-color: #eeeeee;
}
</style>
</head>
<body>
<!--<div>DIV</div>
<span>SPAN</span>
<p>P <button>Button</button></p>--> <div class="myclass">div class="notMe"</div> <div class="myclass otherclass">div class="myClass"</div>
<span class="myclass otherclass">span class="myClass"</span> <script>
// var elements = $("*").css("border","1px solid red").length;
// $("body").prepend("<h3>"+ elements + "elements found</h3>")
$(".myclass.otherclass").css("background-color","red");
</script> </body>
</html>
2.3元素选择器
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="../js/jquery-2.1.1.min.js"></script>
<style type="text/css">
div,span,p {
width: 120px;
text-align: center;
height: 40px;
float: left;
margin: 15px;
padding: 10px;
background-color: #eeeeee;
}
</style>
</head>
<body>
<!--<div>DIV</div>
<span>SPAN</span>
<p>P <button>Button</button></p>--> <!--<div class="myclass">div class="notMe"</div> <div class="myclass otherclass">div class="myClass"</div>
<span class="myclass otherclass">span class="myClass"</span>-->
<p id="heihei">哈哈哈哈哈哈</p>
<p>嘿嘿嘿嘿嘿嘿</p>
<p>吼吼吼吼吼吼</p> <script>
// var elements = $("*").css("border","1px solid red").length;
// $("body").prepend("<h3>"+ elements + "elements found</h3>")
// $(".myclass.otherclass").css("background-color","red");
$("p").css("border","1px solid red");
</script>
</body>
</html>
效果:
2.4 id 选择器
选择一个具有给定ID属性的单个元素
语法
jQuery( "#id" )
id: 一个用来查找的ID,即元素的id属性。/p>
对于ID选择,jQuery使用JavaScript函数document.getElementById(),这是非常有效的。当另一个选择是附加到ID选择器,比如h2#pageTitle,在确定作为匹配的元素前,jQuery执行一个额外的检查。
调用 jQuery() (或 $()) 带上一个选择器作为它的参数,将返回一个jQuery对象包含零个或一个DOM元素的集合。
每个id值在一个文件中只能使用一次。如果多个元素分配了相同的ID,将只匹配该ID选择集合的第一个DOM元素。但这种行为不应该发生;有超过一个元素的文件使用相同的ID是无效的。
例子:
<!DOCTYPE html>
<html>
<head>
<style>
div {
width: 90px;
height: 90px;
float:left;
padding: 5px;
margin: 5px;
background-color: #EEEEEE;
}
</style>
<script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
</head>
<body>
<div id="notMe"><p>id="notMe"</p></div> <div id="myDiv">id="myDiv"</div>
<script>$("#myDiv").css("border","3px solid red");</script> </body>
</html>
效果:
2.5 multiple selector
将每一个选择器匹配到的元素合并后一起返回。
语法
jQuery( "selector1, selector2, selectorN" ) selector1: 任何有效的选择 selector2: 其他有效的选择 selectorN: 更多有效的选择只要你喜欢。
例子
<!DOCTYPE html>
<html>
<head>
<style> div,span,p {
width: 126px;
height: 60px;
float:left;
padding: 3px;
margin: 2px;
background-color: #EEEEEE;
font-size:14px;
}
</style>
<script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
</head>
<body>
<div>div</div> <p class="myClass">p class="myClass"</p>
<p class="notMyClass">p class="notMyClass"</p>
<span>span</span>
<script>$("div,span,p.myClass").css("border","3px solid red");</script> </body>
</html>
效果:
其他的一些选择器
层叠选择器
$("form input") 选择所有的form元素中的input元素
$("#main > *") 选择id值为main的所有的子元素
$("label + input") 选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素
$("#prev ~ div") 同胞选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的div标签
基本过滤选择器
$("tr:first") 选择所有tr元素的第一个
$("tr:last") 选择所有tr元素的最后一个
$("input:not(:checked) + span") 过滤掉:checked的选择器的所有的input元素
$("tr:even") 选择所有的tr元素的第0,2,4... ...个元素(注意:因为所选择的多个元素时为数组,所以序号是从0开始)
$("tr:odd") 选择所有的tr元素的第1,3,5... ...个元素
$("td:eq(2)") 选择所有的td元素中序号为2的那个td元素
$("td:gt(4)") 选择td元素中序号大于4的所有td元素
$("td:ll(4)") 选择td元素中序号小于4的所有的td元素
更多选择器 请看
http://www.cnblogs.com/onlys/archive/2010/12/15/1906380.html