Jquery 之 使用选择器

Posted ck168

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jquery 之 使用选择器相关的知识,希望对你有一定的参考价值。

jQuery选择器描述

jQuery选择器是jQuery框架的基础,jQuery对事件的处理、DOM操作、CSS动态控制、Ajax通信、动画设计都是在选择器基础上进行的。jQuery 选择器采用CSS和Xpath选择符的能力,能够满足用户在DOM中快捷而轻松地获取元素或元素组。

jQuery选择器的种类

基本选择器

层级选择器

伪类选择器(简单的伪类选择器、与内容相关的伪类选择器、与元素显示状态相关的伪类选择器、匹配子元素的伪类选择器、与表单对象相关的伪类选择器、与表单属性相关的伪类选择器)

属性选择器

(1)基本选择器

基本选择器主要包括ID选择器、标签选择器、类选择器、通配选择器和组选择器 5种类型,这与CSS基本选择器类型相一致。

这里主要说一下通配选择器和组选择器

通配选择器能够匹配指定上下文中所有元素。具体用法如下:jQuery("*"); 参数* 为字符串,表示将匹配指定范围内所有的标签元素。

示例:

将匹配文档中<body>标签下包含的所有标签,然后定义所有标签包含的字体显示为红色。

$(function(){

  $("body *").css("color","red");

})

组选择器

jQuery支持CSS的分组选择器,通过这种方式可以扩大选择器的选择范围,同时增强jQuery选择器引擎的应用能力。具体用法如下:jQuery("selector1,selector2,selectorN");

示例:

$(function(){

  $("h2,#wrap,span.red,[title=‘text‘]").css("color","red");

})

(2)层级选择器

层级选择器就是通过DOM嵌套关系结构来实现准确匹配,如果通过DOM元素之间的层次关系来获取特定的元素,那么使用层级选择器将是最佳方式。

层级选择器主要包括 包含选择器、子选择器、相邻选择器和兄弟选择器 4种类型。

包含选择器,就是在给定的祖先元素下匹配所有的后代元素。

示例:$("form input") 可以匹配表单下所有的input元素

子选择器,就是在匹配的父元素下选择所有匹配的子元素。具体用法如下:jQuery("parent>child");

示例:$("form>input")可以匹配表单下所有的子集input元素

相邻选择器,就是在所有匹配的元素后选择同级的相邻元素。具体用法如下:jQuery("prev + next");

示例:$("label + input") 可以匹配所有跟在label后面的input元素

兄弟选择器,就是在所有匹配的元素后选择同级的所有元素。具体用法如下:jQuery("prev ~ siblings");

示例:$("form ~ siblings")可以匹配所有与表单同级结构的input 元素

(3)简单的伪类选择器

伪类可以看作是一种特殊的类选择符,是能被浏览器自动识别的特殊选择符。伪类选择器的最大语法特征就是在选择符中添加“:”标识符。

特定位置选择器:主要包括 :first 、 :last 和 :eq(index) 3种

:first  匹配找到的第1个元素。  例如:$("tr:first") 表示匹配表格的第1行

:last  匹配找到的最后一个元素。 例如: $("tr:last") 表示匹配表格的最后一行

:eq    匹配一个给定索引的元素,从0开始计数。 例如: $("tr:eq(0)")  可以匹配第1行表格行

指定范围选择器:主要包括 :even 、:odd 、:gt(index) 、 :lt(index) 4种。

:even  匹配所有索引值为偶数的元素,从0开始计数。 例如: $("tr:even")可以匹配表格的1,3,5行(即 索引值 0、2、4 ...)

:odd  匹配所有索引值为奇数的元素,从0开始计数。   例如: $("tr:odd")可以匹配表格的 2,4,6行(即 索引值 1、3、5 ...)

:gt    匹配所有大于给定索引值的元素,从0开始技术。  例如: $("tr:gt(0)") 可以匹配第2行及其后面行

:lt     匹配所有小于给定索引值的元素。      例如: $("tr:lt(5)")  可以匹配第5行以及之前的行

排除选择器  :not 选择器比较特殊,它能够在匹配元素集合中排除符合特定匹配规则的元素,也就是说它以反向方式过滤掉不需要的元素。

具体用法如下:jQuery("selector1:not(selector2)");

$("tr:not(tr:lt(3))")  匹配的数据行为 第4行和后面的所有行。

特殊选择器 :animated 和 :header 选择器是两个比较特殊的选择器,它们分别用来匹配动画元素和标题元素。

:header 匹配如  h1、h2、h3 之类的标题元素

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

(4)与内容相关的伪类选择器

主要是根据元素包含内容作为筛选条件进行匹配,这类选择器主要包括4种,如下:

:contains  匹配包含给定文本的元素。  例如: $("div:contains(‘图片‘)")  匹配所有包含“图片”的div元素

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

:has    匹配含有选择器所匹配的元素的元素。  例如: $("div:has(p)")  匹配所有包含p元素的div元素

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

(5)与元素显示状态相关的伪类选择器

:hidden   匹配所有不可见元素,或者type 为hidden的元素

:visible    匹配所有的可见元素

(6)匹配子元素的伪类选择器

子元素选择器主要包括 4 种类型:

:nth-child  匹配其父元素下的第N个子或奇偶元素

:first-child 匹配第一个子元素。   (:first 选择器只匹配一个元素,而:first-child 选择符将为每个父元素匹配一个子元素)

:last-child 匹配最后一个子元素。   (:last 只匹配一个元素,而:last-child 选择符将为每个父元素匹配一个子元素)

:only-child 如果某个元素是父元素中唯一的子元素,那将会被匹配;如果父元素中含有其他元素,那将不会被匹配。

使用表达式的方式:

:nth-child(even)  //匹配偶数位元素

:nth-child(odd)   //匹配奇数位元素

:nth-child(3n)     //匹配第3个及其后面间隔3的每个元素

:nth-child(2)       //匹配第2个元素

:nth-child(3n+1) //匹配第一个及其后面间隔3的每个元素

:nth-child(3n+2) //匹配第二个及其后面间隔3的每个元素

(7)与表单对象相关的伪类选择器

:input  匹配所有input、textarea、select和button元素

:text    匹配所有的单行文本框

:password 匹配所有密码框

:radio   匹配所有单选按钮

:checkbox  匹配所有复选框

:submit   匹配所有提交按钮

:image   匹配所有图像域

:reset     匹配所有重置按钮

:button   匹配所有按钮

:file        匹配所有文件域

:hidden  匹配不可见元素或者type为hidden的元素

(8)与表单属性相关的伪类选择器

:enabled   匹配所有可用元素

:disabled   匹配所有不可用元素

:checked   匹配所有选中的被选中元素(复选框、单选按钮等,不包括 select 中的option)

:selected   匹配所有选中的option 元素

(9)属性选择器

就是根据元素的属性及其值作为过滤条件,来匹配对应的DOM元素。

[attribute]

[attribute=value] 匹配属性等于特定值的元素

例如:   $("input[name=‘text‘]") 表示查找所有name属性值是text的input 元素

[attribute!=value]匹配属性不是特定值的元素

例如:   $("input[name!=‘text‘]") 表示查找所有name属性值不是text的input 元素

[attribute^=value] 匹配给定的属性是以某些值开始的元素

例如:   $("input[name^=‘text‘]") 表示所有name属性值以text开头的input元素

[attribute$=value] 匹配给定的属性是以某些值结尾的元素

例如:   $("input[name$=‘text‘]") 表示所有name属性值以text结束的input 元素

[attribute*=value] 匹配给定的属性是以包含某些值的元素

例如:   $("input[name*=‘text‘]") 表示所有name属性值包含text字符串的input 元素

 

jQuery 选择器应用优化

(1)多用ID选择器

(2)少直接使用Class 选择器

(3)多用父子关系,少用嵌套关系

(4)缓存jQuery对象

 

以上是关于Jquery 之 使用选择器的主要内容,如果未能解决你的问题,请参考以下文章

JQuery之选择器篇

锋利的jQuery学习笔记之jQuery选择器

小白入门之前端网页技术JQuery

jQuery选择器之层级选择器

JQuery之选择器

jQuery之选择器