六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 128|回复: 0

jQuery选择器

[复制链接]

升级  64%

6

主题

6

主题

6

主题

童生

Rank: 1

积分
32
 楼主| 发表于 2013-2-7 22:28:38 | 显示全部楼层 |阅读模式
$的选择器部分:
凡是运用$,其返回值是一个object
$
选择器主要用于选择标签.基本用法是同css的选择器.但是,很让人兴奋的是,他支持常见的浏览器,css中很多选择器是IE6所不支持的.
1.
基本选择器(3):
$("
标签名"),$("p")是选取了所有的p标签节点
$("#id
"),$("#test")是选取了idtest的标签节点
$(".class
"),$(".test")是选取了所有classtest的标签节点
上面的$("标签名")$(".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标签内的所有具有testclass的后代元素(就是被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"),idtest的的节点必须是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.
进一步选择器:
这个名称是我自己起的,其实选择器组合都有进一步的意思,你明白后面所介绍的知识即可.
具有限定子节点选择器:$("mix1[mix2]"):返回包含mix2mix1节点.:$("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值为blockvisible,visibility值为visible元素,不包括hide)
E:hidden:
选择所有隐藏元素(Hide,display值为blockvisible,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

8.xPath
路径查询:

先介绍下xPath的语法:
/:
选取根节点
//:
选取文档中所有符合条件的节点,不管该节点位于何处
.:
选取当前节点
..:
选取单前节点的父节点
@:
选取属性,这个在之前说过了(属性选择器)
nodename:
选取节点下的所有节点
jQuery
中的应用:
根节点是很少用到的,<span class="postbody1"><span style="font-size: 8.5pt; font-family: 宋体;">常用的如下
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表