JQuery选择器

来源:互联网 发布:手机通话记录软件 编辑:程序博客网 时间:2024/05/17 03:18

$的选择器部分:
凡是运用$,其返回值是一个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


$
的其他用法:

$(html
节点):根据提供的原始HTML标记字符串,动态创建由jQuery对象包装的DOM元素.:
$("<div><p>Hello</p></div>").appendTo("#body");//
<div><p>Hello</p></div>添加到body元素中
$(document):
网页文档对象
$(document.body):
网页body对象,$("body")是一样的
$(
函数):DOM载入后就执行该函数.所以$(document).ready()可以写做$()
$(
选择器部分,选择器来源):这个举例说明
$("input:radio",document.forms[0]):
在文档的第一个表单中,搜索所有单选按钮
$("div",xml.responseXML):
查询指定XML文档中的所有div元素
选择器来源可以是:作为上下文的DOM元素,文档或jQuery对象
还有两个:$.extend(prop)$.noConflict()是和插件以及和其他库兼容的使用,以后再写