jQuery学习之二 jQuery选择器
一、jQuery选择器是什么
1.CSS选择器
2.jQuery选择器
二、jQuery选择器的优势
1.简洁的写法
2.支持从CSS1到CSS3选择器
3.完善的处理机制
传统js选择器假如要操作的元素不存在会报错,jq不会,避免了判断存在操作的麻烦
当需要使用jq判断某个元素在网页上是否存在时不能用
if($('#id')){ xxx };
要使用if($('#id').length > 0){ xxx };
或先转化成DOM再判断if($('#id')[0]){ xxx };
三、jQuery选择器
1.基本选择器
#id
.class
element
*
selector1,selector2,...selectorN
2.层次选择器
$('.ancestorClass .sonClass'): 选中所有后代
$('.fatherClass > .sonClass'): 选中子元素
$('prev + next'): 选中代码顺序下一个兄弟
$('prev ~ silbings'): 选中代码顺序后所有兄弟
3.过滤选择器
(1)基本过滤选择器
:first $("div:first")
:last $("div:last")
:not(selector) $("input:not(.myClass)")
:even $("input:even")
:odd $("input:odd")
:eq(index) $("input:eq(1)")
:gt(index) $("input:gt(1)")
:lt(index) $("input:lt(1)")
:header 选取所有标题元素
:animated 选取当前正在执行动画的所有元素
:focus 选取当前获取焦点的元素
(2)内容过滤选择器
:contains(text) 选取文本内容为“text”的元素
:empty 选取不包含子元素或者文本的空元素
:has(selector) 选取含有选择器所匹配的元素的选择器
:parent 选择含有子元素或者文本的元素
(3)可见性过滤选择器
:hidden 选取所有不可见的元素
:visible 选取所有可见的元素
(4)属性过滤选择器
[attribute] 拥有属性
[attribute=value] 属性等于
[attribute!=value] 属性不等于
[attribute^=value] 属性以什么开头
[attribute$=value] 属性以什么结尾
[attribute*=value] 属性中包含什么值
[attribute|=value] 属性以什么为前缀并且后跟'-'做连接
[attribute~=value] 属性以空格分隔的值中含有某值
[attribute1][attribute2][attributeN] 并列过滤
(5)子元素过滤选择器
:nth-child(index/even/odd/equation) 选取每个父元素下的第index个元素或奇偶元素.(index从1算起)、
eg: nth-child(even) nth-child(odd) nth-child(3n) nth-child(3n+1)
:first-child 选取每个父元素的第1个子元素
:last-child 选取每个父元素的最后一个元素
:only-child 如果某个元素是它父元素的唯一子元素,则被选中
(6)表单对象属性过滤选择器
:enabled 选取所有可用元素
:disabled 选取所有不可用元素
:checked 选取所有被选中的元素(单选框,复选框)
:selected 选取所有被选中的选项元素(下拉列表)
判断是否聚焦、可视等可使用is(),eg:
$("xxx").is(":visible")
$("input").is(":enabled")
4.表单选择器
:input 选取所有<input>、<textarea>、<select>、<button> PS.注意$(":input")和$("input")的区别
:text
:password
:radio
:checkbox
:submit
:image
:reset
:button
:file
:hidden
四、应用jQuery改写示例
五、选择器中的一些注意事项
1.选择器中最好不要含有"."、"#"、"("或"]"等特殊字符
如果含有这些特殊字符则需要加转义符转义
eg: <div id="id#b"></div> → 获取:$("#id#b")× $("#id\\#b")√
2.属性选择器的@符号问题
旧版本使用了@,在新版本中已被淘汰
3.选择器中含有空格的注意事项
eg: $(".test :hidden") 指的是带class="test"元素内的被hidden元素
$(".test:hidden") 指的是带class="test"且被隐藏的元素
六、案例研究
filter(expr):筛选出与指定表达式匹配的元素集合,其中expr可以是多个选择器的组合
七、其他选择器
jQuery学习之二 jQuery选择器的更多相关文章
- jQuery学习笔记(二)jQuery中DOM操作
目录 DOM操作分类 jQuery中的各种DOM操作 查找节点 创建节点 删除节点 复制节点 替换节点 包裹节点 属性操作 样式操作 对HTML.文本和值的操作 遍历节点 CSS-DOM操作 小结 本 ...
- jQuery 学习笔记:jQuery 代码结构
jQuery 学习笔记:jQuery 代码结构 这是我学习 jQuery 过程中整理的笔记,这一部分主要包括 jQuery 的代码最外层的结构,写出来整理自己的学习成果,有错误欢迎指出. jQuery ...
- jQuery学习笔记之jQuery的Ajax(3)
jQuery学习笔记之jQuery的Ajax(3) 6.jQuery的Ajax插件 源码地址: https://github.com/iyun/jQueryDemo.git ------------- ...
- jQuery学习笔记(一)jQuery选择器
目录 jQuery选择器的优点 基本选择器 层次选择器 过滤选择器 表单选择器 第一次写博客,希望自己能够长期坚持,以写博客的方式作为总结与复习. 最近一段时间开始学习jQuery,通过写一个jQue ...
- jquery学习笔记(一):选择器
内容来自[汇智网]jquery学习课程 1.1 基础选择器 选择器 功能 返回值 #id 根据给定的id匹配一个元素 单个元素 element 根据给定的元素名匹配所有元素 元素集合 .class 根 ...
- jQuery学习-----(二)JQuery对象与DOM对象的区别与转换
1.jQuery对象和DOM对象的区别 DOM对象,即是我们用传统的方法(javascript)获得的对象,jQuery对象即是用jQuery类库的选择器获得的对象; eg: var domObj = ...
- jquery学习笔记(二):DOM元素操作
内容来自[汇智网]jquery学习课程 2.1 元素属性操作 1.获取元素的属性 语法:attr(name) 参数name表示属性的名称 2.设置元素的属性 单个属性设置语法:attr(key,val ...
- Jquery学习(二)
滚轮事件与函数节流 jquery.mousewheel插件使用 jquery中没有鼠标滚轮事件,原生js中的鼠标滚轮事件不兼容,可以使用jquery的滚轮事件插件jquery.mousewheel.j ...
- jQuery学习之旅 Item2 选择器【二】
这里接着上一个Item1 把jQuery的选择器讲完.主要有:属性过滤器和子元素过滤器 点击"名称"会跳转到此方法的jQuery官方说明文档. 5. 属性过滤器 Attribute ...
随机推荐
- 特征变化--->特征向量中部分特征到类别索引的转换(VectorIndexer)
VectorIndexer: 倘若所有特征都已经被组织在一个向量中,又想对其中某些单个分量进行处理时,Spark ML提供了VectorIndexer类来解决向量数据集中的类别性特征转换. 通过为其提 ...
- SpringBoot 启动定时任务
再项目中大多会使用定时任务来定时执行一些操作,如:文件迁移,备份等等.今天就来跟大家一起学习下如何在SpringBoot中创建定时任务. 1.新建SpringBoot项目,或在原有的项目上添加(不知道 ...
- Potted Flower(线段树+dp)
http://poj.org/problem?id=2750 题意:在一个圈中取若干个相邻的数,求他们的最大序列和.不能够同时取所有的数. 看了一篇解题报告写的很详细..http://blog.csd ...
- JavaScript(JS)的简单使用
一.什么是JS(Javascript)? Javascript是一种脚本语言,被广泛用于Web应用开发,常用来为网页添加各式各样的功能,为用户提供更加流畅的浏览效果. Javascript严格区分大小 ...
- Akka源码分析-Remote-发消息
上一篇博客我们介绍了remote模式下Actor的创建,其实与local的创建并没有太大区别,一般情况下还是使用LocalActorRef创建了Actor.那么发消息是否意味着也是相同的呢? 既然ac ...
- Akka源码分析-ActorSystem
由于本人对Akka比较感兴趣,也用Akka开发了一些系统,但对Akka的源码还没有具体分析过,希望研究源码的同时写一点博客跟大家分享.有不当之处还请指正.我准备采取Debug的方式来研究Akka的运行 ...
- Sum It Up -- 深搜 ---较难
每一行都是一组测试案例 第一个数字 表示总和 第二个数字表示 一共有几个可用数据 现在 按照从小到大的顺序 输出 那些数字中若干数字之和为总和的 信息 /. 很好很明显的 遍历痕迹 , ...
- SQL之T-sql 语句操作数据库
用SQL语句操作数据库 在上一次的话题中我们谈到了怎么使用数据库,说到了数据库的基本用法. 不过只是仅限于一些简单的操作,so 如果你不想被人说--"你们只是动动鼠标操作就可以了! 没什么技 ...
- SAS学习笔记之《SAS编程与数据挖掘商业案例》(1)系统简介和编程基础
SAS学习笔记之<SAS编程与数据挖掘商业案例>(1)系统简介和编程基础 1. SAS系统简介 1.1 SAS是先编译后执行的语言,data步标志着编译的开始. 数据指针:当前内存缓存区, ...
- Android popwindow 消失监听
LisviewPop.setOnDismissListener(new OnDismissListener() { @Override public void onDismiss() { //改变显示 ...