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 相关文章推荐
用js判断用户浏览器是否是XP SP2的IE6
Mar 08 Javascript
利用JS自动打开页面上链接的实现代码
Sep 25 Javascript
利用javascript数组长度循环数组内所有元素
Dec 27 Javascript
js利用数组length属性清空和截短数组的小例子
Jan 15 Javascript
jquery 自定义容器下雨效果可将下雨图标改为其他
Apr 23 Javascript
javascript定义变量时加var与不加var的区别
Dec 22 Javascript
Highcharts学习之坐标轴
Aug 02 Javascript
javascript的函数劫持浅析
Sep 26 Javascript
简单实现AngularJS轮播图效果
Apr 10 Javascript
BootStrap给table表格的每一行添加一个按钮事件
Sep 07 Javascript
基于vue-ssr的静态网站生成器VuePress 初体验
Apr 17 Javascript
vue实现公共方法抽离
Jul 31 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
Content-type 的说明
2006/10/09 PHP
帖几个PHP的无限分类实现想法~
2007/01/02 PHP
发一个php简单的伪原创程序,配合商城采集用的
2010/10/12 PHP
PHP 计算代码执行耗时的代码修正网上普遍错误
2011/05/14 PHP
PHP实现基于文本的摩斯电码生成器
2016/01/11 PHP
PHPStrom 新建FTP项目以及在线操作教程
2016/10/16 PHP
js函数获取html中className所在的内容并去除标签
2013/09/08 Javascript
JavaScript中为什么null==0为false而null大于=0为true(个人研究)
2013/09/16 Javascript
jquery判断小数点两位和自动删除小数两位后的数字
2014/03/19 Javascript
javascript 3d 逐侦产品展示(核心精简)
2014/03/26 Javascript
一个JavaScript操作元素定位元素的实例
2014/10/29 Javascript
使用jquery插件qrcode生成二维码
2015/10/22 Javascript
node.js程序作为服务并在windows下开机自启动(用forever)
2017/03/29 Javascript
使用vue-router设置每个页面的title方法
2018/02/11 Javascript
Vue动态控制input的disabled属性的方法
2018/06/26 Javascript
Vue下拉框回显并默认选中随机问题
2018/09/06 Javascript
vue中使用vue-cli接入融云实现即时通信
2019/04/19 Javascript
layui操作列按钮个数和文字颜色的判断实例
2019/09/11 Javascript
微信小程序顶部导航栏可滑动并选中放大
2019/12/05 Javascript
[03:59]第二届DOTA2亚洲邀请赛选手传记-VGJ.rOtk
2017/04/03 DOTA
[27:08]完美世界DOTA2联赛PWL S2 SZ vs Rebirth 第二场 11.21
2020/11/23 DOTA
Python yield 小结和实例
2014/04/25 Python
代码讲解Python对Windows服务进行监控
2018/02/11 Python
Python内建序列通用操作6种实现方法
2020/03/26 Python
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
美国综合购物商城:UnbeatableSale.com
2018/11/28 全球购物
牵手50香港:专为黄金岁月的单身人士而设的交友网站
2020/08/14 全球购物
生产主管岗位职责
2013/11/10 职场文书
单位承诺书格式
2014/05/21 职场文书
项目经理任命书
2014/06/04 职场文书
爱与责任师德演讲稿
2014/08/26 职场文书
2014年企业工会工作总结
2014/11/12 职场文书
街道社区活动报告
2015/02/05 职场文书
财政局个人年终总结
2015/03/03 职场文书
毕业生自荐信范文
2015/03/05 职场文书
课程设计感想范文
2015/08/11 职场文书