您有个知识币

【退出】

jquery选择器

$的选择器部分:

凡是运用$,其返回值是一个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></p></div>对这里的p段落标签有效.但对

<div><p><p></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.位置选择器

位置选择器主要是根据元素的位置进行选择,

div a:first 返回页面第一个在div中的a

div a last 返回页面最后一个在div中的a

div odd 返回页面偶数位置的div

div even 返回页面奇数位置的idv

div first-child 返回div 中第一个子选择

div last-child 返回div 中最后一个子选择

only-child 没有兄弟节点的元素

nth-child(n):第n个子节点

eq(n) 第n个匹配元素

gt(n) n之后的匹配元素 不包含

lt(n) n之前的匹配元素 不包含

8.进一步选择器: 

这个名称是我自己起的,其实选择器组合都有进一步的意思,你明白后面所介绍的知识即可.

具有限定子节点选择器:$("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的子元素

E:empty:没有子元素(包括text节点)的类型为E的元素

E:enabled

E:disabled:类型为E,允许或被禁止的用户界面元素

E:checked:类型为E,处于选中状态的用户界面元素(例如单选按钮或复选框)

E:visible:选择所有可见元素(display值为block或visible,visibility值为visible元素,不包括hide域)

E:hidden:选择所有隐藏元素(非Hide域,且display值为block或visible,visibility值为visible的元素)

E:not(s):类型为E,不匹配选择器s

E:eq(n),E:gt(n),E:lt(n):元素限定

E:first:相当于E:eq(0)

E:last:最后一个匹配的元素

E:even:从匹配的元素集中取序数为偶数的元素

E:odd:从匹配的元素集中取序数为奇数的元素

E:parent:选择包含子元素(包含text节点)的所有元素

E:contains('test'):选择所有含有指定文本的元素

表单选择器:

E:input:选择表单元素(input,select,textarea,button)

E:text:选择所有文本域(type="text")

E:password:选择所有密码域(type="password")

E:radio:选择所有单选按钮(type="radio")

E:checkbox:选择所有复选框(type="checkbox")

E:submit:选择所有提交按钮(type="submit")

E:image:选择所有图像域 (type="image")

E:reset:选择所有清除域(type="reset")

E:button:选择所有按钮(type="button")

当然包括E:hidden

9.xPath路径查询: 

先介绍下xPath的语法:

/:选取根节点

//:选取文档中所有符合条件的节点,不管该节点位于何处

.:选取当前节点

..:选取单前节点的父节点

@:选取属性,这个在之前说过了(属性选择器)

nodename:选取节点下的所有节点

本文固定链接: http://www.webzhishi.com/jquery_selector/ | web知识网

jquery选择器:等您坐沙发呢!

发表评论