本章节主要Jquery选择器

jquery选择器与css选择器十分相似,特别需要注意的是

<script type="text/javascript">
document.getElementById("tt").style.color="red"/*若没有"tt"元素,浏览器者会报错*/
</script> <script type="text/javascript">
if(document.getElementById("tt"){
document.getElementById("tt").style.color="red";
)
</script>

$("#tt")获取的永远是对象,即使没有此元素也不会报错,同理

错

if($("#tt")){
//代码
} 对 if($("#tt").length>0){
//代码
} 或者转换为DOM对象也是对的 if($("#tt")[0]){
//代码
}

层次选择器

$("ancestor descendant")  空格表示选取祖先元素里所有的此类后代元素;

$("parent>child") 大于号表示选取父元素下的子元素(相隔一代);

$("prev+next")加号表示选取紧接在此元素后面的下一个同辈元素,可使用next()方法代替如

$(".one+div");等价于$(".one").next("div");

<li><span>Name</span><inputtype="text"/><inputtype="text"/></li>
 $("span+input").所有<span>后面的文本框

$("prev~siblings")~表示选取此元素后面的所有同辈元素,可使用nextAll()方法代替如

$("#prev~div");等价于$("#prev").nextAll("div");

过滤选择器

1.基本过滤选择器

:first选取第一个元素,$("div:first");

:last选取最后一个元素;

:not(selector)去除所有给定选择器匹配的元素;

:even选取索引是偶数的所有元素,索引从0开始;

:odd选取索引是奇数的所有元素,索引从0开始;

:eq(index)选取索引等于index的元素,index从0开始;(单个元素)

:gt(index)选取索引大于index的元素,index从0开始;(不包括index本身)

:lt(index)选取索引小于index的元素,index从0开始;(不包括index本身)

:header选取所有标题元素,h1、h2等;

:animated选取当前正在执行动画的所有元素,$("div:animated")选取正在执行动画的<div>元素

:focus选取当前获取焦点的元素,$(":focus")

2.内容过滤器

:contains(text)选取含有文本内容为"text"的元素,$("div:contains('我')")

:empty选取不包含子元素或者文本的空元素,$("div:empty")

:has(selector)选取含有选择器所匹配的元素的元素,$("div:has(p)"),选取含有<p>元素的<div>元素

:parent选取含有子元素或者文本的元素$("div:parent")

3.可见性过滤选择器

:hidden选取所有不可见的元素$(":hidden")也可以$("input:hidden")

:visible选取所有可见的元素$("div:visible")

4.属性过滤选择器

[attribute]选取拥有此属性的元素,$("div[id]")选取拥有id这个属性的元素

[attribute=value]选取属性值为value的元素,$("div[title=test]")选取属性title为"test"的<div>元素

[attribute!=value]选取属性值不等于value的元素,同上相反,没有属性title的<div>也会被选取

[attribute^=value]选取属性值以value开头的元素,类似第二条

[attribute$=value]选取属性值以value结束的元素,类似第二条

[attribute*=value]选取属性的值含有value的元素,类似第二条

[attribute|=value]选取属性等于给定串或以该字符串为前缀(有"-")的元素,$("div[title|='en']")选取title为en或以en为前缀

[attribute~=value]选取属性用空格分隔的值中包含一个给定值的元素,$("div[title~='uk']")选取属性title用空格分隔的值中包含字符uk的元素

[attribute1][attribute2][attributeN],复合属性选择器,$("div[id][title$='test']")选取拥有id并且title以"test"结束的<div>元素

5.子元素过滤选择器(注意:此类过滤选择器所选取的均为集合元素)

:nth-child(index/even/odd/equation)选取每个父元素下的第index个子元素或者奇偶元素(index从1算起)

:first-child选取每个父元素的第一个子元素$("ul li:first-child")

:last-child选取每个父元素的最后一个子元素

:only-child如果某个元素是它父元素中唯一的子元素,那么将会被匹配;如果父元素中含有其他元素,则不会被匹配,

$("ul li:only-child")在<ul>中选取是唯一子元素的<li>元素

6.表单对象属性过滤选择器

:enabled选取所有可用元素$("#form1:enabled")

:disabled选取所有不可用元素$("#form2:disabled")(设置过disabled="disabled")

:checked选取所有被选中的元素(单选框,复选框)$("input:checked");选取所有被选中的<input>元素

:selected选取所有被选中的选项元素(下拉列表)$("select option:selected");选取所有被选中的选项元素

表单选择器

:input选取所有的<input>、<textarea>、<select>和<button>元素,$(":input")语法下同

:text选取所有的单行文本框

:password选取所有的密码框

:radio选取所有的单选框

:checkbox选取所有的多选框

:submit选取所有的提交按钮

:image选取所有的图像按钮

:reset选取所有的重置按钮

:button选取所有的按钮

:file选取所有的上传域

:hidden选取所有的不可见元素

选择器中的注意事项

选择器中含有"."、"#"、"("或"]"等特殊字符需要使用转义符,$("#id\\#b")  id值为"id#b"

在jQuery1.3.1版本不需要在属性前添加@符号

空格使用也尤为重要,如var $t_a=(".test :hidden")选取class为"test"元素里面的隐藏元素,

var $t_a=(".test:hidden")选取隐藏的class为"test"的元素

《锋利的Jquery第二版》读书笔记 第二章的更多相关文章

  1. 《ECMAScript标准入门》第二版读书笔记

    title: <ECMAScript标准入门>第二版 date: 2017-04-10 tags: JavaScript categories: Reading-note 2015年6月, ...

  2. 《细说PHP》第二版--读书笔记

    第五章 PHP的基本语法 5.2.4 在程序中使用空白的处理 5.3 变量 5.3.1 变量的声明 在php中变量的声明必须是使用一个$符号,后面跟变量名来表示 unset()函数释放指定变量 iss ...

  3. sed&awk第二版读书笔记

    1. POSIX标准对正则表达式字符和操作符的含义进行了形式化.这种标准定义了两类正则表达式:基本的正则表达式(BRE),grep和sed使用这种正则表达式;扩展的表达式,egrep和awk使用这种正 ...

  4. think in java 第四版读书笔记 第一章对象导论

    很久没有碰过java了,为了项目需要以及以后找工作,还是有必要将think in java通读一遍.欢迎大家一起讨论学习 1.1抽象过程 面向对象语言的5个特性: 1.万物皆对象 任何事物都可以抽象为 ...

  5. 《javascript权威指南》读书笔记——第二篇

    <javascript权威指南>读书笔记——第二篇 金刚 javascript js javascript权威指南 今天是今年的196天,分享今天的读书笔记. 第2章 词法结构 2.1 字 ...

  6. Docker技术入门与实战 第二版-学习笔记-10-Docker Machine 项目-2-driver

    1>使用的driver 1〉generic 使用带有SSH的现有VM/主机创建机器. 如果你使用的是机器不直接支持的provider,或者希望导入现有主机以允许Docker Machine进行管 ...

  7. Docker技术入门与实战 第二版-学习笔记-8-网络功能network-3-容器访问控制和自定义网桥

    1)容器访问控制 容器的访问控制,主要通过 Linux 上的 iptables防火墙来进行管理和实现. iptables是 Linux 上默认的防火墙软件,在大部分发行版中都自带. 容器访问外部网络 ...

  8. Linux设备驱动程序 第三版 读书笔记(一)

    Linux设备驱动程序 第三版 读书笔记(一) Bob Zhang 2017.08.25 编写基本的Hello World模块 #include <linux/init.h> #inclu ...

  9. Primer C++第五版 读书笔记(一)

    Primer C++第五版 读书笔记(一) (如有侵权请通知本人,将第一时间删文) 1.1-2.2 章节 关于C++变量初始化: 初始化不是赋值,初始化的含义是创建变量时赋予其一个初始值,而赋值的含义 ...

  10. 单元测试之道Java版——读书笔记

    单元测试知道Java版读书笔记 首先我们必须要知道我们所写的代码,它的功能是什么,如果我们不了解代码的行为,那么也就无从测试. 我们测试的目的,是为了我们整个程序架构的稳定,代码其实就是欧文要实现功能 ...

随机推荐

  1. Headfirst设计模式的C++实现——抽象工厂(Abstract Factory)

    Dough.h #ifndef _DOUGH_H #define _DOUGH_H class Dough { }; #endif ThinCrustDough.h #ifndef _THIN_CRU ...

  2. 高性能、高并发TCP服务器(多线程调用libevent)

    from:http://blog.csdn.net/i_am_jojo/article/details/7587838 本文讲述的TCP服务器是模仿memcache中的TCP网络处理框架,其中是基于l ...

  3. OpenCV2学习笔记02:MSVC2013搭建OpenCV开发环境

    我这里编译的库是通过手动编译的.只是需要注意的是,手动编译一般会产生大量的文件,差不多7个多G的样子,实在是有点浪费硬盘存储呀,其实我们可以删除掉没有用的东西.因为我们在编译的时候指定了一个目录比如我 ...

  4. c#代码自动修改解决方案下任意文件

    命名空间 using EnvDTE;using EnvDTE80; private DTE2 _applicationObject; public void AutoAddControl(插件 v_f ...

  5. php表单发送到邮箱V1.0

    html表单代码: <form action="index.php" name="form" method="POST"> &l ...

  6. mysqli 取出数据库中某表的表头和内容

    需求如题 取出数据库中某表的表头和内容,并显示该表的行数和列数 <?php //显示表内容的函数 function showTable($tableName){ //连接数据库 $mysqli= ...

  7. (转载)EhLib 在 Delphi 7 下的安装方法

    EhLib 在 Delphi 7 下的安装方法 1.将 EhLib 解压到一个目录,如:E:\VCL\EhLib: 2.将 EhLib 安装目录下 Common 目录.DataService 目录下的 ...

  8. 基于ARM-LINUX的温度传感器驱动(DS18B20) .

    DS18B20数字温度传感器接线方便,封装成后可应用于多种场合,如管道式,螺纹式,磁铁吸附式,不锈钢封装式,型号多种多样,有LTM8877,LTM8874等等.主要根据应用场合的不同而改变其外观.封装 ...

  9. JavaBean的使用

    JavaBean主要用于实现一些业务逻辑或封装一些业务对象 通常将JavaBean中的属性设置为私有的(private),但需要为其提供公共的(public)访问方法,也就是所说的getXXX()方法 ...

  10. codeforces 278Div1 B题

    虚拟参赛的时候没想到是线段树,看到很多人都过了,也蛮着急的. 首先用二分+线段树的方法更新DP[i]:它表示以A[i]为结尾可以最前到哪个位置: 再用线段树计算ans[i]:它表示当前i个A元素可以最 ...