![](https://csdnimg.cn/release/download_crawler_static/4441713/bg1.jpg)
$的选择器部分:
凡是运用$,其返回值是一个 object
$选择器主要用于选择标签.基本用法是同 css 的选择器.但是,很让人兴奋的是,他支持常见的浏览器,而 css 中很
多选择器是 IE6 所不支持的.
1.基本选择器(3 种):
$("标签名"),如$("p")是选取了所有的 p 标签节点
$("#id 名"),如$("#test")是选取了 id 为 test 的标签节点
$(".class 名"),如$(".test")是选取了所有 class 为 test 的标签节点
上面的$("标签名")和$(".class 名")返回的都是所有满足的节点,至于进一步筛选可以添加一些函数,如 eq,gt,lt
等等.
2.组选择器:
下面还是现做一个约定:把"标签名或#id 名或.class 名"记作 mix,则 mix 表示一个标签名,或一个#id 或一
个.class.
$("mix,mix,mix,..."),如:$("div,#test1,p,.test2,#test3")
3.后代选择器:
$("mix mix"),当然可以是多个嵌套,但后代选择器可以是深层子代,所以$("mix mix mix ...")这种写法作用不
大.例子:$("div .test"):在 div 标签内的所有具有 test 的 class 的后代元素(就是被 div 嵌套的 class 属性为 test
的标签)
可以见 DEMO。
4.子选择器:
$("mix>mix"),这个放在后代选择器后面是为了和它做对比 .子选择器只能选择第一代子代.不处理深层嵌套.例
子:
$("div>.test")
<div><p class="test"></p></div>对这里的 p 段落标签有效.但对
<div><p><p class="test"></p></p></div>对这里的 p 段落标签无效,这里要用
$("div .test)
5.临近选择器:
$("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_value
7.进一步选择器: