jQuery选择器全面总结


Posted in Javascript onJanuary 06, 2014

jQuery 的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法  

jQuery选择器使得获得页面元素变得更加容易、更加灵活,从而大大减轻了开发人员的压力。如同盖楼一样,没有砖瓦,就盖不起楼房。得不到元素谈何其他各种操作呢?可见,jQuery选择器的重要性。当然想一下子掌握所有选择器也是很困难的,这个得靠实践和积累。

现在我们正式进入jQuery选择器的学习。我们将jQuery选择器进行分类学习,将jQuery选择器分为以下几种:

1、基本选择器

◦id                              根据元素ID选择
◦elementname       根据元素名称选择
◦classname            根据元素css类名选择

举例:

<input type="text" id="ID" value="根据ID选择" />

<a>根据元素名称选择</a>

<input type="text" class="classname" value="根据元素css类名选择" />
jQuery("#ID").val();

jQuery("a").text();

jQuery(".classname").val();

即可分别得到元素的值。以上三种为最常见的选择器,其中ID选择器是效率最高的,在可能的情况下应该尽量使用它。

2、层次选择器

◦ancestor descendant  祖先和子孙选择器
◦parent > child           父子节点选择器
◦prev + next                同级别选择器
◦prev ~ siblings         过滤选择器

举例:

<div id="divTest">

    <input type="text" value="投资" />

    <input id="next" type="text" />

    <input type="text"  value="担当" />

    <input type="text" title="学习" value="学习" />

    <a>1</a>

    <a>2</a>

</div>
//得到div中的a标签内容 结果为12

jQuery("#divTest a").text();

//输出div直接子节点 结果为投资

jQuery("#divTest>input").val();

//输出id为next的后一个同级别元素 结果为担当

jQuery("#next+input").val();

//同上,并且是有title的元素 结果为学习

jQuery("#next~[title]").val();

3、基本过滤选择器

◦:first                       找到第一元素
◦:last                       找到最后一个元素
◦:not(selector)      去除与给定选择器匹配的元素
◦:even                     匹配索引值为偶数的元素 从0开始计数
◦:odd                       匹配索引值为奇数的元素 从0开始计数
◦:eq(index)             匹配一个给定索引值元素 从0开始
◦:gt(index)              匹配大于给定索引值元素
◦:lt(index)               匹配小于给定索引值元素
◦:header                 选择h1,h2,h3一类的标签 (目前没用过)
◦:animated             匹配正执行动画效果的元素 (目前没用过)

举例:

<div id="divTest">

    <ul>

        <li>投资</li>

        <li>理财</li>

        <li>成熟</li>

        <li>担当</li>

        <input type="radio" value="学习" checked="checked" />

        <input type="radio" value="不学习" />

    </ul>

</div>
//第一个li内容 结果为投资

jQuery("li:first").text();

//最后一个li内容 结果为担当

jQuery("li:last").text();

//input未被选中的值 结果为不学习

jQuery("li input:not(:checked)").val();

//索引为偶数的li 结果为投资 成熟

jQuery("li:even").text();

//索引为奇数的li 结果为理财 担当

jQuery("li:odd").text();

//索引大于2的li的内容 结果为担当

jQuery("li:gt(2)").text();

//索引小于1的li的内容 结果为投资

jQuery("li:lt(1)").text();

4、内容过滤器

◦:contains(text)              匹配包含给定文本的元素
◦:empty                        匹配所有不包含子元素或者文本的空元素
◦:has(selector)              匹配含有选择器所匹配的元素

举例:

<div id="Test">

    <ul>

        <li>hyip投资</li>

        <li>hyip</li>

        <li></li>

        <li>理财</li>

        <li><a>投资</a></li>

    </ul>

</div>  
//包含hyip的li的内容 结果为hyip投资 hyip

jQuery("li:contains('hyip')").text();

//内容为空的li的后一个li内容 结果为理财

jQuery("li:empty+li").text();

//包含a标签的li的内容 结果为投资

jQuery("li:has(a)").text();

5、可见性过滤器

◦:hidden    匹配不可见元素
◦:visible     匹配可见元素

举例:

<ul>

    <li>可见</li>

    <li style="display:none;">不可见</li>

</ul>
//不可见的li的内容 结果为不可见

jQuery("li:hidden").text();

//可见的li的内容 结果为可见

jQuery("li:visible").text();

6、属性过滤器

◦[attribute=value]                 匹配属性是给定值的元素
◦[attribute^=value]               匹配属性是以给定值开始的元素
◦[attribute$=value]              匹配属性是以给定值结束的元素
◦[attribute*=value]               匹配属性包含给定值的元素

举例:

<input type="text" name="hyipinvest" value="hyip投资" />

<input type="text" name="investhyip" value="投资hyip" />

<input type="text" name="google" value="HYIP" />

//name为hyipinvest的值 结果为hyip投资

alert(jQuery("input[name='hyipinvest']").val());

//name以hyip开始的值 结果为hyip投资

alert(jQuery("input[name^='hyip']").val());

//name以hyip结束的值 结果为投资hyip

alert(jQuery("input[name$='hyip']").val());

//name包含oo的值 结果为HYIP

alert(jQuery("input[name*='oo']").val());

jQuery选择器就总结到这里,这些基本上都是在学习过程中遇到的,还有极少部分没有总结出来。经过一段时间实践,相信大家就能够熟练的使用jQuery选择器了。
 
$("#myELement")    选择id值等于myElement的元素,id值不能重复在文档中只能有一个id值是myElement所以得到的是唯一的元素 
$("div")           选择所有的div标签元素,返回div元素数组 
$(".myClass")      选择使用myClass类的css的所有元素 
$("*")             选择文档中的所有的元素,可以运用多种的选择方式进行联合选择:例如$("#myELement,div,.myclass") 
 
层叠选择器: 
$("form input")         选择所有的form元素中的input元素 
$("#main > *")          选择id值为main的所有的子元素 
$("label + input")     选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素 
$("#prev ~ div")       同胞选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的div标签 
 
基本过滤选择器: 
$("tr:first")               选择所有tr元素的第一个 
$("tr:last")                选择所有tr元素的最后一个 
$("input:not(:checked) + span")   
 
过滤掉:checked的选择器的所有的input元素 
 
$("tr:even")               选择所有的tr元素的第0,2,4... ...个元素(注意:因为所选择的多个元素时为数组,所以序号是从0开始) 
 
$("tr:odd")                选择所有的tr元素的第1,3,5... ...个元素 
$("td:eq(2)")             选择所有的td元素中序号为2的那个td元素 
$("td:gt(4)")             选择td元素中序号大于4的所有td元素 
$("td:ll(4)")              选择td元素中序号小于4的所有的td元素 
$(":header") 
$("div:animated") 

内容过滤选择器: 
 
$("div:contains('John')") 选择所有div中含有John文本的元素 
$("td:empty")           选择所有的为空(也不包括文本节点)的td元素的数组 
$("div:has(p)")        选择所有含有p标签的div元素 
$("td:parent")          选择所有的以td为父节点的元素数组 

可视化过滤选择器: 
 
$("div:hidden")        选择所有的被hidden的div元素 
$("div:visible")        选择所有的可视化的div元素 

属性过滤选择器: 
 
$("div[id]")              选择所有含有id属性的div元素 
$("input[name='newsletter']")    选择所有的name属性等于'newsletter'的input元素 
 
$("input[name!='newsletter']") 选择所有的name属性不等于'newsletter'的input元素 
 
$("input[name^='news']")         选择所有的name属性以'news'开头的input元素 
$("input[name$='news']")         选择所有的name属性以'news'结尾的input元素 
$("input[name*='man']")          选择所有的name属性包含'news'的input元素 
 
$("input[id][name$='man']")    可以使用多个属性进行联合选择,该选择器是得到所有的含有id属性并且那么属性以man结尾的元素 
 
子元素过滤选择器: 
 
$("ul li:nth-child(2)"),$("ul li:nth-child(odd)"),$("ul li:nth-child(3n + 1)") 
 
$("div span:first-child")          返回所有的div元素的第一个子节点的数组 
$("div span:last-child")           返回所有的div元素的最后一个节点的数组 
$("div button:only-child")       返回所有的div中只有唯一一个子节点的所有子节点的数组 
 
表单元素选择器: 
 
$(":input")                  选择所有的表单输入元素,包括input, textarea, select 和 button 
 
$(":text")                     选择所有的text input元素 
$(":password")           选择所有的password input元素 
$(":radio")                   选择所有的radio input元素 
$(":checkbox")            选择所有的checkbox input元素 
$(":submit")               选择所有的submit input元素 
$(":image")                 选择所有的image input元素 
$(":reset")                   选择所有的reset input元素 
$(":button")                选择所有的button input元素 
$(":file")                     选择所有的file input元素 
$(":hidden")               选择所有类型为hidden的input元素或表单的隐藏域 
 
表单元素过滤选择器: 
 
$(":enabled")             选择所有的可操作的表单元素 
$(":disabled")            选择所有的不可操作的表单元素 
$(":checked")            选择所有的被checked的表单元素 
$("select option:selected") 选择所有的select 的子元素中被selected的元素 
 
 
选取一个 name 为”S_03_22″的input text框的上一个td的text值
$(”input[@ name =S_03_22]“).parent().prev().text() 
 
名字以”S_”开始,并且不是以”_R”结尾的
$(”input[@ name ^='S_']“).not(”[@ name $='_R']“) 
 
一个名为 radio_01的radio所选的值
$(”input[@ name =radio_01][@checked]“).val(); 
 
 
$("A B") 查找A元素下面的所有子节点,包括非直接子节点
$("A>B") 查找A元素下面的直接子节点
$("A+B") 查找A元素后面的兄弟节点,包括非直接子节点
$("A~B") 查找A元素后面的兄弟节点,不包括非直接子节点 
 
1. $("A B") 查找A元素下面的所有子节点,包括非直接子节点 
 
例子:找到表单中所有的 input 元素 
 
HTML 代码: 
<form>
<label>Name:</label>
<input name="name" />
<fieldset>
      <label>Newsletter:</label>
      <input name="newsletter" />
</fieldset>
</form>
<input name="none" /> 

jQuery 代码: 
$("form input") 

结果: 
[ <input name="name" />, <input name="newsletter" /> ] 
 
2. $("A>B") 查找A元素下面的直接子节点 

例子:匹配表单中所有的子级input元素。 
 
HTML 代码: 
<form>
<label>Name:</label>
<input name="name" />
<fieldset>
      <label>Newsletter:</label>
      <input name="newsletter" />
</fieldset>
</form>
<input name="none" /> 

jQuery 代码: 
$("form > input") 

结果: 
[ <input name="name" /> ] 
 
3. $("A+B") 查找A元素后面的兄弟节点,包括非直接子节点 

例子:匹配所有跟在 label 后面的 input 元素 
 
HTML 代码: 
<form>
<label>Name:</label>
<input name="name" />
<fieldset>
      <label>Newsletter:</label>
      <input name="newsletter" />
</fieldset>
</form>
<input name="none" /> 

jQuery 代码: 
$("label + input") 

结果: 
[ <input name="name" />, <input name="newsletter" /> ] 
 
4. $("A~B") 查找A元素后面的兄弟节点,不包括非直接子节点 

例子:找到所有与表单同辈的 input 元素 
 
HTML 代码: 
<form>
<label>Name:</label>
<input name="name" />
<fieldset>
      <label>Newsletter:</label>
      <input name="newsletter" />
</fieldset>
</form>
<input name="none" /> 

jQuery 代码: 
$("form ~ input") 

结果: 
[ <input name="none" /> ]

Javascript 相关文章推荐
基于JQuery的浮动DIV显示提示信息并自动隐藏
Feb 11 Javascript
JS动态调用方法名示例介绍
Dec 18 Javascript
jquery获取radio值(单选组radio)
Oct 16 Javascript
ECMA5数组的新增方法有哪些及forEach()模仿实现
Nov 03 Javascript
javascript实现瀑布流动态加载图片原理
Aug 12 Javascript
JavaScript中数据类型转换总结
Dec 25 Javascript
Bootstrap导航简单实现代码
Mar 06 Javascript
使用requirejs模块化开发多页面一个入口js的使用方式
Jun 14 Javascript
React学习之事件绑定的几种方法对比
Sep 24 Javascript
Node.js学习之查询字符串解析querystring详解
Sep 28 Javascript
微信小程序 scroll-view的使用案例代码详解
Jun 11 Javascript
js面向对象编程OOP及函数式编程FP区别
Jul 07 Javascript
JavaScript定义类的几种方式总结
Jan 06 #Javascript
javascript函数定义的几种区别小结
Jan 06 #Javascript
javascript 用函数语句和表达式定义函数的区别详解
Jan 06 #Javascript
js形成页面的一种遮罩效果实例代码
Jan 04 #Javascript
JavaScript将数据转换成整数的方法
Jan 04 #Javascript
jquery.post用法关于type设置问题补充
Jan 03 #Javascript
JQuery处理json与ajax返回JSON实例代码
Jan 03 #Javascript
You might like
php代码把全角数字转为半角数字
2007/12/10 PHP
获取远程文件大小的php函数
2010/01/11 PHP
php利用cookie实现自动登录的方法
2014/12/10 PHP
php中的动态调用实例分析
2015/01/07 PHP
PHP获取用户访问IP地址的5种方法
2016/05/16 PHP
PHP封装的数据库保存session功能类
2016/07/11 PHP
PHP+swoole+linux实现系统监控和性能优化操作示例
2019/04/15 PHP
关于JavaScript的一些看法
2009/05/27 Javascript
扩展easyui.datagrid,添加数据loading遮罩效果代码
2010/11/02 Javascript
基于jquery的3d效果实现代码
2011/03/23 Javascript
非常漂亮的JS+CSS图片幻灯切换特效
2013/11/20 Javascript
jQuery中:password选择器用法实例
2015/01/03 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
JS组件Bootstrap实现弹出框效果代码
2016/04/26 Javascript
js检测离开或刷新页面时表单数据是否更改的方法
2016/08/02 Javascript
webpack独立打包和缓存处理详解
2017/04/03 Javascript
Vue.js实现输入框绑定的实例代码
2017/08/24 Javascript
基于vue-resource jsonp跨域问题的解决方法
2018/02/03 Javascript
vue动态改变背景图片demo分享
2018/09/13 Javascript
如何基于JavaScript判断图片是否加载完成
2019/12/28 Javascript
JS关闭子窗口并且刷新上一个窗口的实现示例
2020/03/10 Javascript
python使用cStringIO实现临时内存文件访问的方法
2015/03/26 Python
python搜索指定目录的方法
2015/04/29 Python
Python中类型关系和继承关系实例详解
2015/05/25 Python
利用Python生成文件md5校验值函数的方法
2017/01/10 Python
浅谈python中的实例方法、类方法和静态方法
2017/02/17 Python
解决Scrapy安装错误:Microsoft Visual C++ 14.0 is required...
2017/10/01 Python
对numpy中数组元素的统一赋值实例
2018/04/04 Python
Python把csv数据写入list和字典类型的变量脚本方法
2018/06/15 Python
Flask框架学习笔记之路由和反向路由详解【图文与实例】
2019/08/12 Python
初学者学习Python好还是Java好
2020/05/26 Python
工程管理英文求职信
2014/03/18 职场文书
银行业务授权委托书
2014/10/10 职场文书
微观世界观后感
2015/06/10 职场文书
环境保护宣传标语大全!
2019/06/28 职场文书
如何设计高效合理的MySQL查询语句
2021/05/26 MySQL