jQuery 选择器

来源:互联网 发布:linux查看检测网络命令 编辑:程序博客网 时间:2024/04/18 15:50

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.层次选择器

3.1后代选择器: 

$("mix mix"),当然可以是多个嵌套,但后代选择器可以是深层子代,所以$("mix mix mix ...")这种写法作用不大.例子:$("div .test"):在div标签内的所有具有test的class的后代元素(就是被div嵌套的class属性为test的标签) 

3.2.子选择器: 

$("mix>mix"),这个放在后代选择器后面是为了和它做对比.子选择器只能选择第一代子代.不处理深层嵌套.例子: 

$("div>.test") 

<div><p class="test"></p></div>对这里的p段落标签有效.但对 

<div><p><p class="test"></p></p></div>对这里的p段落标签无效,这里要用 

$("div .test) 

3.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>则不能取到 

3.4~

匹配 prev 元素之后的所有 siblings 元素

4.过滤选择器(也叫简单选择器)

4.1 :first 匹配找到的第一个元素

4.2 :last 匹配找到的最后一个元素

4.3  :not

去除所有与给定选择器匹配的元素

在jQuery 1.3中,已经支持复杂选择器了(例如:not(div a) 和 :not(div,a))

$("input:not(:checked)") 

4.4  :even

匹配所有索引值为偶数的元素,从 0 开始计数

4.5  :odd

匹配所有索引值为奇数的元素,从 0 开始计数

4.6  :eq(index)

匹配一个给定索引值的元素

4.7   :gt(index)

匹配所有大于给定索引值的元素

4.8    :lt(index)

匹配所有小于给定索引值的元素

4.9     :header

匹配如 h1, h2, h3之类的标题元素  $(":header").css("background", "#EEE"); 

4.10    :animated

匹配所有正在执行动画效果的元素

$("#run").click(function(){

  $("div:not(:animated)").animate({ left: "+=20" }, 1000);

}); 

5.内容过滤选择器

5.1  :contains(text)   匹配包含给定文本的元素

5.2  :empty         匹配所有不包含子元素或者文本的空元素

5.3  :has(selector)    匹配含有选择器所匹配的元素的元素

5.4  :parent          匹配含有子元素或者文本的元素

6.可见性过滤选择器

6.1  :hidden

匹配所有的不可见元素,input 元素的 type 属性为 "hidden" 的话也会被匹配到

6.2   :visible

匹配所有的可见元素

7.属性过滤选择器

7.1 [attribute]

匹配包含给定属性的元素。注意,在jQuery 1.3中,前导的@符号已经被废除!如果想要兼容最新版本,只需要简单去掉@符号即可。

7.2  [attribute=value]

匹配给定的属性是某个特定值的元素

7.3  [attribute!=value]

匹配所有含有指定的属性,但属性不等于特定值的元素。

在jQuery 1.3之前是这样的:"匹配那些没有指定的属性的元素,或者指定的属性不等于特定值的元素。",这等价于:not([attr=value])

7.4  [attribute^=value]

匹配给定的属性是以某些值开始的元素

7.5   [attribute$=value]

匹配给定的属性是以某些值结尾的元素

7.6   [attribute*=value]

匹配给定的属性是以包含某些值的元素

7.7   [selector1][selector2][selectorN]

复合属性选择器,需要同时满足多个条件时使用。

8.子元素过滤选择器

8.1  :nth-child(index/even/odd/equation)

匹配其父元素下的第N个子或奇偶元素

8.2  :first-child

匹配第一个子元素

8.3  :last-child

匹配最后一个子元素

8.4  :only-child

如果某个元素是父元素中唯一的子元素,那将会被匹配

9.表单对象过滤选择器

案例研究:

实现如下效果:

10.其它:
具有限定子节点选择器:$("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

 

关键代码:

1.首先第5条以后的品牌隐藏:

隐藏:

var $category = $('ul li:gt(5):not(:last)');   //索引大于5的li集合元素,并且不包含最后一个  

$category.hide();

2.显示

var $toggleBtn = $('div.showmore > a');             //  获取“显示全部品牌”按钮

$toggleBtn.click(function(){

$category.show();                     //  显示$category

$('.showmore a span')

.css("background","url(img/up.gif) no-repeat 0 0")      

.text("精简显示品牌");                  //改变背景图片(上、下)和文本

$('ul li').filter(":contains('佳能'),:contains('尼康'),:contains('奥林巴斯')")

.addClass("promoted"); //添加高亮样式

return false;        //超链接不跳转

})

3.切换

var $category = $('ul li:gt(5):not(:last)');   //获得索引值大于5的品牌集合对象(除最后一条)

$category.hide(); //  隐藏上面获取到的jQuery对象。

var $toggleBtn = $('div.showmore > a');          //  获取“显示全部品牌”按钮

$toggleBtn.click(function(){

if($category.is(":visible")){

$category.hide();                     //  隐藏$category

$('.showmore a span')

.css("background","url(img/down.gif) no-repeat 0 0")      

.text("显示全部品牌");                  //改变背景图片和文本

$('ul li').removeClass("promoted"); // 去掉高亮样式

}else{

$category.show();                     //  显示$category

$('.showmore a span')

.css("background","url(img/up.gif) no-repeat 0 0")      

.text("精简显示品牌");                  //改变背景图片和文本

$('ul li').filter(":contains('佳能'),:contains('尼康'),:contains('奥林巴斯')")

.addClass("promoted"); //添加高亮样式

 }

return false;        //超链接不跳转

})

 


11.xPath路径查询:
先介绍下xPath的语法:
/:选取根节点
//:选取文档中所有符合条件的节点,不管该节点位于何处
.:选取当前节点
..:选取单前节点的父节点
@:选取属性,这个在之前说过了(属性选择器)
nodename:选取节点下的所有节点
jQuery中的应用:
根节点是很少用到的,常用的如下面的例子:
$("div/p")相当于$("div>p")
$("div//p")相当于$("div p")
$("//div/../p"):所有div节点的父节点下的p标签
还有相对路径的写法以及支持的Axis选择器,还不是会应用,不介绍了...已经一大堆了


$的其他用法:
$(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()是和插件以及和其他库兼容的使用,以后再写

jQuery的core部分还有:
eq(数字):将匹配的元素集合缩减为一个元素。这个元素在匹配元素集合中的位置变为0,而集合长度变成1
gt(数字):将匹配的元素集合缩减为给定位置之后的所有元素
lt(数字):将匹配的元素集合缩减为给定位置之前的所有元素
上面三个的例子:
$("div:eq(1)")//第2个div
$("div:gt(2)")//第3个div以及之后的div
$("div:lt(2)")//第2个div以及之前的div,即第1个div和第2个div

length或size():当前匹配的元素数量
each():以每一个匹配的元素作为上下文来执行一个函数。这意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的元素(每次都是一个不同的匹配元素).而且,在每次执行函数时,都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数.
$("img").each(function(i){ this.src = "test" + i + ".jpg"; });//迭代图像,并设置它们的src属性
get():如果没有参数,返回所有,是一个对象数组;如果带参数,必须是数字,基数从0开始.例子:
$("div").get():返回一个div对象数组
$("div").get(1):返回第二个div对象
index(需求的元素节点对象):返回数字.用个例子说明:
$("div").index($(".test"))[1] //表示从所有div节点中查找class属性为test的节点.并且找的是第二个节点(基数从0开始).返回值是该节点在div节点中的位置(基数也是从0开始).

 

 

原创粉丝点击