当前位置: 首页 > news >正文

jQuery选择器总结

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

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"  /> ]

转载于:https://my.oschina.net/u/1167421/blog/546469

相关文章:

  • 静态路由动态路由的差别
  • ActiveMQ快速入门
  • Java8 十大新特性详解
  • MyBatis学习总结(1)——MyBatis快速入门
  • 大型网站技术架构(三)架构核心要素
  • 什么是语法糖?
  • command injection命令注入
  • java 发送邮件
  • apt-fast
  • Excel导出通用操作方式
  • 我感恩
  • 如何清除Exchange2010邮件日志
  • 人类的殒落与扬升
  • 304441事务管理与并发控制
  • 【412】Linux 系统编译 C 程序
  • $translatePartialLoader加载失败及解决方式
  • 2019年如何成为全栈工程师?
  • Android开源项目规范总结
  • Flannel解读
  • interface和setter,getter
  • Js基础知识(一) - 变量
  • miaov-React 最佳入门
  • Node + FFmpeg 实现Canvas动画导出视频
  • Selenium实战教程系列(二)---元素定位
  • Spring核心 Bean的高级装配
  • Vue官网教程学习过程中值得记录的一些事情
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 翻译 | 老司机带你秒懂内存管理 - 第一部(共三部)
  • 解决iview多表头动态更改列元素发生的错误
  • 前端代码风格自动化系列(二)之Commitlint
  • 深度解析利用ES6进行Promise封装总结
  • 跳前端坑前,先看看这个!!
  • 微信小程序:实现悬浮返回和分享按钮
  • 我与Jetbrains的这些年
  • 小程序开发之路(一)
  • 深度学习之轻量级神经网络在TWS蓝牙音频处理器上的部署
  • 阿里云服务器购买完整流程
  • ​插件化DPI在商用WIFI中的价值
  • (02)Hive SQL编译成MapReduce任务的过程
  • (09)Hive——CTE 公共表达式
  • (1)常见O(n^2)排序算法解析
  • (arch)linux 转换文件编码格式
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (第9篇)大数据的的超级应用——数据挖掘-推荐系统
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (汇总)os模块以及shutil模块对文件的操作
  • (五)IO流之ByteArrayInput/OutputStream
  • (转)VC++中ondraw在什么时候调用的
  • * CIL library *(* CIL module *) : error LNK2005: _DllMain@12 already defined in mfcs120u.lib(dllmodu
  • *上位机的定义
  • .bat批处理(二):%0 %1——给批处理脚本传递参数
  • .NET Core MongoDB数据仓储和工作单元模式封装
  • .NET 除了用 Task 之外,如何自己写一个可以 await 的对象?
  • .Net8 Blazor 尝鲜
  • .NET程序员迈向卓越的必由之路