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 相关文章推荐
JavaScript URL参数读取改进版
Jan 16 Javascript
Mootools 1.2教程 滑动效果(Slide)
Sep 15 Javascript
表单JS弹出填写提示效果代码
Apr 16 Javascript
jQuery学习笔记 操作jQuery对象 CSS处理
Sep 19 Javascript
javascript数组操作(创建、元素删除、数组的拷贝)
Apr 07 Javascript
jquery操作复选框checkbox的方法汇总
Feb 05 Javascript
JQuery使用index方法获取Jquery对象数组下标的方法
May 18 Javascript
jQuery获取checkboxlist的value值的方法
Sep 27 Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 Javascript
JS全角与半角转化实例(分享)
Jul 04 Javascript
详解三种方式解决vue中v-html元素中标签样式
Nov 22 Javascript
小程序富文本提取图片可放大缩小
May 26 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
漫威DC御用漫画家去世 他的表情包曾走红网络
2020/04/09 欧美动漫
PHP动态变静态原理
2006/11/25 PHP
PHP中::、-&amp;gt;、self、$this几种操作符的区别介绍
2013/04/24 PHP
基于PHP异步执行的常用方式详解
2013/06/03 PHP
php处理复杂xml数据示例
2016/07/11 PHP
利用PHP如何统计Nginx日志的User Agent数据
2019/03/06 PHP
javascript实现动态模态绑定grid过程代码
2014/09/22 Javascript
javascript面向对象之共享成员属性与方法及prototype关键字用法
2015/01/13 Javascript
详解JavaScript的Polymer框架中的通知交互
2015/07/29 Javascript
Javascript将双字节字符转换成单字节字符并计算长度
2016/06/22 Javascript
js判断文件格式及大小的简单实例(必看)
2016/10/11 Javascript
JavaScript 身份证号有效验证详解及实例代码
2016/10/20 Javascript
Bootstrap Img 图片样式(推荐)
2016/12/13 Javascript
用户管理的设计_jquery的ajax实现二级联动效果
2017/07/13 jQuery
vue的事件绑定与方法详解
2017/08/16 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
2018/06/04 Javascript
javascript显示动态时间的方法汇总
2018/07/06 Javascript
使用JavaScript实现node.js中的path.join方法
2018/08/12 Javascript
解决JavaScript layui 下拉框不显示的问题
2018/08/14 Javascript
对vue中methods互相调用的方法详解
2018/08/30 Javascript
微信小程序swiper禁止用户手动滑动代码实例
2019/08/23 Javascript
简单了解微信小程序 e.target与e.currentTarget的不同
2019/09/27 Javascript
Python编程中的文件读写及相关的文件对象方法讲解
2016/01/19 Python
Python实现登陆文件验证方法
2018/10/06 Python
使用Python 正则匹配两个特定字符之间的字符方法
2018/12/24 Python
python爬取基于m3u8协议的ts文件并合并
2019/04/26 Python
Python实现UDP程序通信过程图解
2020/05/15 Python
Happy Plugs官网:瑞典无线耳机品牌
2020/07/16 全球购物
杭州联环马网络笔试题面试题
2013/08/04 面试题
个人自我鉴定总结
2014/03/25 职场文书
食品安全责任书
2014/04/15 职场文书
球队口号
2014/06/18 职场文书
房屋登记授权委托书范本
2014/10/09 职场文书
群众路线专项整治工作情况报告
2014/10/28 职场文书
六种css3实现的边框过渡效果
2021/04/22 HTML / CSS
java代码实现空间切割
2022/01/18 Java/Android