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 相关文章推荐
Hutia 的 JS 代码集
Oct 24 Javascript
屏蔽Flash右键信息的js代码
Jan 17 Javascript
Js控制弹窗实现在任意分辨率下居中显示
Aug 01 Javascript
JavaScript分页功能的实现方法
Apr 25 Javascript
在JavaScript中处理时间之getHours()方法的使用
Jun 10 Javascript
jQuery模拟物体自由落体运动(附演示与demo源码下载)
Jan 21 Javascript
jQuery控制元素隐藏和显示
Mar 03 Javascript
微信小程序中时间戳和日期的相互转换问题
Jul 09 Javascript
js实现GIF动图分解成多帧图片上传
Oct 24 Javascript
Vue 封装防刷新考试倒计时组件的实现
Jun 05 Javascript
浅谈JavaScript中的“!!”作用
Aug 03 Javascript
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 Vue.js
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
joomla内置的表单验证功能使用方法
2010/06/11 PHP
php站内搜索并高亮显示关键字的实现代码
2011/12/29 PHP
linux下安装php的memcached客户端
2014/08/03 PHP
php使用GD库创建图片缩略图的方法
2015/06/10 PHP
PHP的消息通信机制测试实例
2016/11/10 PHP
phpinfo的知识点总结
2019/10/10 PHP
Thinkphp5.0框架视图view的循环标签用法示例
2019/10/12 PHP
safari,opera嵌入iframe页面cookie读取问题解决方法
2010/06/23 Javascript
让人印象深刻的10个jQuery手风琴效果应用
2012/05/08 Javascript
当达到输入长度时表单自动切换焦点
2014/04/06 Javascript
extjs 如何给column 加上提示
2014/07/29 Javascript
jquery实现拖拽调整Div大小
2015/01/30 Javascript
超赞的动手创建JavaScript框架的详细教程
2015/06/30 Javascript
基于JavaScript代码实现pc与手机之间的跳转
2015/12/23 Javascript
JS阻止事件冒泡行为和闭包的方法
2016/06/16 Javascript
Bootstrap进度条实现代码解析
2017/03/07 Javascript
Angular 5.x 学习笔记之Router(路由)应用
2018/04/08 Javascript
微信小程序实现弹出层效果
2020/05/26 Javascript
JS实现获取当前所在周的周六、周日示例分析
2019/05/11 Javascript
Nuxt使用Vuex的方法示例
2019/09/06 Javascript
vue路由跳转传递参数的方式总结
2020/05/10 Javascript
JavaScript中的执行环境和作用域链
2020/09/04 Javascript
Python描述器descriptor详解
2015/02/03 Python
详解Python import方法引入模块的实例
2017/08/02 Python
使用Python实现租车计费系统的两种方法
2018/09/29 Python
使用Python实现分别输出每个数组
2019/12/06 Python
使用Python 自动生成 Word 文档的教程
2020/02/13 Python
python中68个内置函数的总结与介绍
2020/02/24 Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
2020/06/12 Python
Jupyter notebook命令和编辑模式常用快捷键汇总
2020/11/17 Python
html5 初试 indexedDB(推荐)
2016/07/21 HTML / CSS
Aosom西班牙:家具在线商店
2020/06/11 全球购物
小学师德师风演讲稿
2014/09/02 职场文书
交通局领导班子群众路线教育实践活动对照检查材料思想汇报
2014/10/09 职场文书
公司授权委托书
2014/10/17 职场文书
在CSS中使用when/else的方法
2022/01/18 HTML / CSS