JQuery选择器特辑 详细小结


Posted in Javascript onMay 14, 2012

这是看《锋利的jquery》时,整理出来的一些东西,很多方法,需要大家亲自实践一下,才会理解得更加深刻,切莫眼高手低哦……

Jquery选择器分类:基本选择器,层次选择器,过滤选择器,表单选择器

一、基本选择器jquery中最常用的选择器,也是最简单的选择器。通过元素idclass和标签名等来查找DOM元素。

-基本选择器

选择器 描述 返回 示例
#id 根据给定的id匹配一个元素 单个元素 $(“#test”)选取id为test的元素
.class 根据给定的类名匹配元素 集合元素 $(“.test”)选取所有class为test的元素
element 根据给定的的元素名匹配元素 集合元素 $(“p”) 选取所有的

元素

* 匹配所有元素 集合元素 $(“*”)选取所有元素
Selector1,Selector2, ……, SelectorN 将每一个选择器匹配到的元素合并后一起返回 集合元素 $(“div,span,p.myClass”)选取所有
,和拥有class为myClass的

标签的一组元素

二、层次选择器:通过DOM元素之间的层次关系获取特定元素,如后代元素、子元素、相邻元素、兄弟元素等。层次选择器是一个很好的选择

-层次选择器

选择器 描述 返回 示例
$(“ancestor  descendant”) 选取ancestor元素里所有descendant(后代)元素 集合元素 $(“div span”)选取
里所有的元素
$(“parent>child”) 选取父元素下的子元素 集合元素 $(“div>span”)选取
下元素名为的子元素
$(‘prev+next') 选取紧接在prev元素后的next元素 集合元素 $(‘.one+div') 选取class为one的下一个
元素(相邻元素)
$(‘prev~siblings') 选取prev元素之后的所有元素 集合元素 $(‘.one+div') 选取class为one的元素后面所有
兄弟元素

 

注意:

$(‘prev+next')选择器与next()方法的等价关系

$(‘.one+div')    等价于     $(“.one”).next(“div”)

$(‘prev~siblings')选择器与nextAll()方法的等价关系

$(‘.one~div')     等价于    $(“.one”).nextAll(“div”)

 

三、过滤选择器:主要是通过特定的过滤选择器规则来筛选出所需的DOM元素,过滤规则与css中伪类选择器语法相同,即选择器都以一个冒号(:)开头。

按照不同的过滤规则,过滤选择器分为:基本过滤选择器、内容过滤选择器、可见性过滤选择器、属性过滤选择器、子元素过滤选择器、表单对象属性座率选择器

 

1-基本过滤选择器

 

选择器 描述 返回 示例
:first 选取第一个元素 单个元素 $(“div:first”)选取所有
元素中第一个
元素
:last 选取最后一个元素 单个元素 $(“div:last”)选取所有
元素中最后一个
元素
:not(selector) 去除所有与给定选择器匹配的元素 集合元素 $(“input:not(.myClass)”) 选取class为不是myClass的元素
:even 选取索引是偶数的所有元素,索引从0开始 集合元素 $(“input:even”) 选取索引是偶数的元素
:odd 选取索引是奇数的所有元素,索引从0开始 集合元素 $(“input:odd”) 选取索引是奇数的元素
:eq(index) 选取索引等于index的元素(index从0开始) 单个元素 $(“input:eq(1)”选取索引为1的元素
:gt(index) 选取索引大于index的元素(index从0开始) 集合元素 $(“input:gt(1)”) 选取索引大于1的元素(注:大于1,而不包括1)
:lt(index) 选取索引小于index的元素(index从0开始) 集合元素 $(“input:gt(1)”) 选取索引小于1的元素(注:小于1,而不包括1)
:header 选取所有的标题元素,例如h1,h2,h3等待 集合元素 $(“:header”)选取网页中所有的

……

:animated 选取当前正在执行动画的所有元素 集合元素 $(“div:animated”)选取正在执行动画的
元素

 

2-内容过滤选择器

 

选择器 描述 返回 示例
:contains(text) 选取含有文本内容为”text”的元素 集合元素 $(“div:contains(‘我')”)选取含有文本“我”的
元素
:empty 选取不包含子元素或者文本的空元素 集合元素 $(“div:empty”)选取不包含子元素(包括文本元素)的
空元素
:has(selector) 选取含有选择器所匹配的元素的元素 集合元素 $(“div:has(p)”) 选取含有

元素的

元素
:parent 选取含有子元素或者文本元素 集合元素 $(“div:parent”) 选取拥有子元素(包括文本元素)的
元素

 

3-可见性过滤选择器

 

选择器 描述 返回 示例
:hidden 选取所有不可见的元素 集合元素 $(“:hidden”)选取所有不可见的元素。包括
等元素。如果只想选取元素,可以使用$(“input:hidden”)
:visible 选取不包含子元素或者文本的空元素 集合元素 $(“div:visible”)选取所有可见的
元素

 

4-属性过滤选择器

 

选择器 描述 返回 示例
[attribute] 选取拥有此属性的元素 集合元素 $(“div[id]”)选取拥有属性id的元素
[attribute=value] 选取属性的值为value的元素 集合元素 $(“div[title=test]”)选取属性title为”test”的
元素
[attribute!=value] 选取属性的值不等于value的元素 集合元素 $(“div[title!=test]”)选取属性title不等于”test”的
元素(注意:没有属性的title的
元素也会被选取)
[attribute^=value] 选取属性的值以value开始的元素 集合元素 $(“div[title^=test]”)选取属性title以”test”开始的
元素
[attribute$=value] 选取属性的值以value结束的元素 集合元素 $(“div[title$=test]”)选取属性title以”test”结束的
元素
[attribute*=value] 选取属性值含有value的元素 集合元素 $(“div[title*=test]”)选取属性title含有”test”的
元素
[selector1][selector2][selectorN] 用属性选择器合并成一个复合属性选择器,满足多个条件。每个选择一次,缩小一次范围 集合元素 $(“div[id][title$='tets']”)选取拥有属性id,并且属性title以”test”结束的
元素

5-子元素过滤选择器

 

选择器 描述 返回 示例
:nth-child(index/even/odd/equation) 选取每个父元素下的第index个子元素或者奇偶元素(index从1算起) 集合元素 :eq(index)只匹配一个元素,而:nth-child将为每一个父元素匹配子元素,并且:nth-child(index)的index是从1开始的,而:eq(index)是从0算起
:first-child 选取每个父元素的第一个子元素 集合元素 :first只返回单个元素,而:first-child选择符将为每个父元素匹配第一个子元素
:last-child 选取每个父元素的最后一个子元素 集合元素 :last只返回单个元素,而:last-child选择符将为每个父元素匹配最后一个子元素
:only-child 如果某个元素是它父元素中唯一的子元素,那么将会被匹配。如果父元素中含有其他元素,则不会被匹配 集合元素  

:nth-child()选择器详细功能

1:nth-child(even)能选取每个父元素下的索引值是偶数的元素。

2:nth-child(odd) 能选取每个父元素下的索引值是奇数的元素。

3:nth-child(2)能选取每个父元素下的索引值等于2的元素

4:nth-child(3n)能选取每个父元素下的索引值是3的倍数的元素,(n0开始)。

5:nth-child(3n+1)能选取每个父元素的索引值是(3n+1)的元素。(n0开始)

6-表单对象属性过滤选择器

 

选择器 描述 返回 示例
:enabled 选取所有可用元素 集合元素 $(“#form1:enabled”) ;选取id为”form1”的表单内的所有可用元素
:disabled 选取所有不可用元素 集合元素 $(“#form1:disabled”) ;选取id为”form1”的表单内的所有不可用元素
:checked 选取所有被选中的元素(单选框,复选框) 集合元素 $(“input:checked”);选取所有被选中的元素
:selected 选取所有被选中的选项元素(下拉列表) 集合元素 $(“select:selected”);选取所有被选中的选项元素

四、表单选择器

-表单对象属性过滤示例

 

选择器 描述 返回 示例
:input 选取所有可用元素 集合元素 $(“:input”) 选取所有
:text 选取所有不可用元素 集合元素 $(“:text”) 选取所有的单行文本
:password 选取所有的密码框 集合元素 $(“: password”)选取所有的密码框
:radio 选取所有的单选框 集合元素 $(“:radio”)选取所有的单选框
:checkbox 选取所有的多选框 集合元素 $(“:checkbox”)选取所有的多选框
:submit 选取所有的提交按钮 集合元素 $(“:submit”)选取所有的提交按钮
:image 选取所有的图像按钮 集合元素 $(“:image”)选取所有的图像按钮
:reset 选取所有的重置按钮 集合元素 $(“:reset”)选取所有的重置按钮
:button 选取所有的按钮 集合元素 $(“:button”)选取所有按钮
:file 选取所有的上传域 集合元素 $(:file)选取所有的上传域
:hidden 选取所有不可见元素 集合元素 $(“:hidden”)选取所有不可见元素
紫陌言:吾生也有涯而知也无涯……
Javascript 相关文章推荐
JQueryEasyUI datagrid框架的进阶使用
Apr 08 Javascript
JavaScript 中的日期和时间及表示标准介绍
Aug 21 Javascript
ie9 提示'console' 未定义问题的解决方法
Mar 20 Javascript
jQuery插件之jQuery.Form.js用法实例分析(附demo示例源码)
Jan 04 Javascript
AngularJS入门教程之控制器详解
Jul 27 Javascript
vue Element-ui input 远程搜索与修改建议显示模版的示例代码
Oct 19 Javascript
Laravel整合Bootstrap 4的完整方案(推荐)
Jan 25 Javascript
原生JS实现的双色球功能示例
Feb 02 Javascript
为jquery的ajax请求添加超时timeout时间的操作方法
Sep 04 jQuery
JavaScript函数IIFE使用详解
Oct 21 Javascript
在微信小程序中使用mqtt服务的方法
Dec 13 Javascript
Javascript实现打鼓效果
Jan 29 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
May 14 #Javascript
js split 的用法和定义 js split分割字符串成数组的实例代码
May 13 #Javascript
jQuery循环滚动展示代码 可应用到文字和图片上
May 11 #Javascript
基于jQuery的公告无限循环滚动实现代码
May 11 #Javascript
javascript 事件处理、鼠标拖动效果实现方法详解
May 11 #Javascript
通过百度地图获取公交线路的站点坐标的js代码
May 11 #Javascript
疯狂Jquery第一天(Jquery学习笔记)
May 11 #Javascript
You might like
PHP json格式和js json格式 js跨域调用实现代码
2012/09/08 PHP
php中json_encode处理gbk与gb2312中文乱码问题的解决方法
2014/07/10 PHP
PDO防注入原理分析以及使用PDO的注意事项总结
2014/10/23 PHP
php pthreads多线程的安装与使用
2016/01/19 PHP
php socket通信(tcp/udp)实例分析
2016/02/14 PHP
详解thinkphp实现excel数据的导入导出(附完整案例)
2016/12/29 PHP
JavaScript 图片预览效果 推荐
2009/12/22 Javascript
javascript JSON操作入门实例
2010/04/16 Javascript
jquery jqPlot API 中文使用教程(非常强大的图表工具)
2011/08/15 Javascript
js解析与序列化json数据(一)json.stringify()的基本用法
2013/02/01 Javascript
jQuery操作表格(table)的常用方法、技巧汇总
2014/04/12 Javascript
网页实时显示服务器时间和javscript自运行时钟
2014/06/09 Javascript
下拉框select的绑定示例
2014/09/04 Javascript
jQuery()方法的第二个参数详解
2015/04/29 Javascript
Bootstrap禁用响应式布局的实现方法
2017/03/09 Javascript
jQuery ajax实现省市县三级联动
2021/03/07 Javascript
利用js的闭包原理做对象封装及调用方法
2017/04/07 Javascript
AngularJS 实现购物车全选反选功能
2017/10/24 Javascript
vue.js或js实现中文A-Z排序的方法
2018/03/08 Javascript
Vue2.0仿饿了么webapp单页面应用详细步骤
2018/07/08 Javascript
详解如何为你的angular app构建一个第三方库
2018/12/07 Javascript
小程序开发中如何使用async-await并封装公共异步请求的方法
2019/01/20 Javascript
微信小程序HTTP接口请求封装代码实例
2019/09/05 Javascript
js实现视图和数据双向绑定的方法分析
2020/02/05 Javascript
JavaScript/TypeScript 实现并发请求控制的示例代码
2021/01/18 Javascript
[02:34]2016完美“圣”典风云人物:BurNIng专访
2016/12/10 DOTA
跟老齐学Python之使用Python操作数据库(1)
2014/11/25 Python
Python bsddb模块操作Berkeley DB数据库介绍
2015/04/08 Python
利用python批量修改word文件名的方法示例
2017/10/17 Python
Python异常对代码运行性能的影响实例解析
2018/02/08 Python
Linux-ubuntu16.04 Python3.5配置OpenCV3.2的方法
2018/04/02 Python
详解django.contirb.auth-认证
2018/07/16 Python
python编写实现抽奖器
2020/09/10 Python
教育学专业实习生的自我鉴定
2013/11/26 职场文书
护士爱岗敬业心得体会
2016/01/25 职场文书
Java面试题冲刺第十八天--Spring框架3
2021/08/07 面试题