1.基本选择器(3种):
a、$(“标签名”):,如$(“p”)是选取了所有的p标签节点(这个选择器可以选择这个页面中所有的这个标签)b、$(“#id名”),如$(“#test”)是选取了id为test的标签节点(这个选择器是按id名进行选择的,我们要记着,选择器如果id名前加#号,class前加点号)
c、$(“.class名”),如$(“.test”)是选取了所有class为test的标签节点(这种选择器就是选择特定class的标签)2.组选择器: 把三种基本的选择器用逗号隔开就是我们的组选择器
下面还是现做一个约定:把”标签名或#id名或.class名”记作mix,则mix表示一个标签名,或一个#id或一个.class. $(“mix,mix,mix,…”),如:$(“div,#test1,p,.test2,#test3”)(这样们就可以任意的去选择标签并给他们相同的方法了)3.后代选择器: —-3种基本选择器的组合,“ ”隔开,直系皆生效
$(“mix mix”),当然可以是多个嵌套,但后代选择器可以是深层子代,所以$(“mix mix mix …”)这种写法作用不大.例子:$(“div .test”):在div标签内的所有具有test的class的后代元素(就是被div嵌套的class属性为test的标签)4.子选择器: —-3种基本选择器的组合,“>”隔开,只亲子有效
$(“mix>mix”),这个放在后代选择器后面是为了和它做对比.子选择器只能选择第一代子代.不处理深层嵌套.例子: $(“div>.test”) <div><p></p></div>对这里的p段落标签有效.但对 <div><p><p></p></p></div>对这里的p段落标签无效,这里要用 $(“div .test)5.临近选择器: —-3种基本选择器的组合,“+”隔开,只下一个兄弟节点
$(“mix+mix”),选取下一个兄弟节点.如:$(“div +#test”),id为test的的节点必须是div的下一个兄弟节点. <div></div><p id=”test”></p>在$(“div + #test”)中能取到p段落节点 <div></div><p></p><p id=”test”></p>则不能取到6.属性选择器: —-“ |=|^|$|*”
把属性选择器不放在css选择器里面是因为jQuery中写法是不一样的.至于css中写法可以参考我之前写的一篇css的选择器一文.jQuery中是和xPath类似的写法:$(“mix[@attr]”):选取所有该mix且具有attr属性的节点$(“mix[@attr=a_value”]):选取所有该mix且具有attr属性并满足属性值为a_value的节点$(“mix[@attr^=a_value_head”]):attr属性的属性值是以a_value_head开头的$(“mix[@attr$=a_value_end”]):attr属性的属性值是以a_value_end结尾的$(“mix[@attr*=a_value”]):attr属性的属性值中包含a_value7. 限定选择器:
这个名称是我自己起的,其实选择器组合都有限定的意思,你明白后面所介绍的知识即可.具有限定子节点选择器:$(“mix1[mix2]”):返回包含mix2的mix1节点.如:$(“div[a]”):包含a标签的div.这个和$(“div a”)不相同.后者表示div中的a标签,返回的是a标签对象,前者返回的是div标签对象冒号限定结点选择器:$(“mix:condition”):mix标签,并且满足限定条件.E:root:类型为E,并且是文档的根元素E:nth-child(n):是其父元素的第n个类型为E的子元素 ,基数从1开始E:first-child:是其父元素的第1个类型为E的子元素E:last-child:是其父元素的最后一个类型为E的子元素E:only-child:且是其父元素的唯一一个类型为E的子元素