JQuery选择器总结

下周的项目应该又要做前台的东西,把JQuery的选择器查询并总结一下,一来加深印象,二来可以作为以后查询.

1.常用的选择器:

$("#idchoose")               选择一个id为idchoose的元素.

$(".class")                   选择一个class样式为class的元素.

$("input[name='person']")          选择一个name为person的input框.

$("h4:contains('John')")              选择一个包含"John"的h4标题元素.

$("*")                   选择文档中的所有的元素

$("p.intro") 选取所有 class="intro" 的 <p> 元素。

$("p#demo") 选取所有 id="demo" 的 <p> 元素。

$(".title,.item")选取所有class为title和class为item的元素

  通常情况为了防止因为自己思考有误而导致选择器出错,最简单直接的方法就是在html页面的元素上插入一个id然后用id选择器来进行选择.虽然class选择器也可以做到唯一选择,但是考虑的美工大大们可能修改class,所以相比之下还是id选择器比较靠谱一点.

  不过一个页面的id选择器是唯一的,当你有两个或者更多的同名id的时候,只会默认选择第一个该id的元素,所以id选择器不能用来进行批量选择,所以需要批量选择的时候(比如把页面内的所有的输入框都设置成readonly),显然需要使用$("input[type='text']")这种有过滤的元素选择器来完成的.当然clss也可以用来进行批量选择,同样的,考虑的前台还有美工大大们的活,就不要用class选择器了,万一发生了误删或者样式名字改变这种悲剧的事情,会很伤心的.

下面是一些JQuery选择器的分类总结:

总结大部分参考前辈快乐的langYa的博文以及W3C的JQuery教程,链接见文章最后.

元素选择器:

$("p")           选择所有的<p>元素

通常情况下,元素选择器都是与过滤选择器一起结合使用的,如:$("p:[type='hidden']"),选择tpye属性为hidden的所有<p>元素.
注释

 层叠选择器:

$("form input")         选择所有的form元素中的input元素 

$("#main > *")          选择id值为main的所有的子元素 

//这个选择器与$("#main").children()所达成的效果是一样的,所以在选择元素的时候并不一定要通过选择器来完成,灵活的使用祖先和后代遍历一样也可以完成查找功能.
注释

/* $("label + input")     选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素 */ 

模仿这个选择器写了一个demo,但是并没有出现预想到的结果(貌似啥都没有选到),时间关系暂时不去研究了,以后有空在验证一下.
注释

 $("#prev ~ div")       同胞选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的div标签  

//同样的 我们也可以利用同胞遍历来完成这个能:$("#prev").siblings("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:lt(4)")              选择td元素中序号小于4的所有的td元素 

$(":header")            选择h1、h2、h3之类的  

$("div:animated")     选择正在执行动画效果的元素 

内容过滤选择器:

$("div:contains('John')") 选择所有div中含有John文本的元素

这只是一个例子,contains(text)是一个比较常用的过滤选择器,但是在实际的应用过程中应该尽量避免直接使用元素选择器来搭配contain(text),比如有这样一段代码:
<div id="form">
   <p>主div</p>
     <div id="second">
             <p>我是第二层<p>
             <div id="goal">
                    <p>我是要被找到的目标</p>
             </div
     </div>
 </div>  

如果我们想选择选择id为goal的那个div,如果使用$("div:contains('目标')") ,那么三个div层都会被选中,以为外层的连个div也嵌套的id为goal的div以及他的内容,所以外层的两个div也包含了文本"目标",他们也会被选中,所以在这种情况下使用最好能够唯一选择的选择器来配合contains(text)完成条件过滤                            //

$("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属性通常因为要与后台相对应经常是唯一的,所以经常用$("input[name='newsletter']")这种形式做唯一选择.用input的type属性,$("input[type='text']"),做批量选择.
注释

$("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").first()会简洁一点.另外,子元素选择器的选择只限于在子元素中,但是当需要对孙元素进行操作的时候,使用子元素过滤器就会产生错误的选择,错误例子暂时先不例举了,这时候正确的写法应当是$("div").find("span").first()

$("div span:last-child")           返回所有的div元素的最后一个节点的数组      //同样的,$(div span).last()

$("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的元素

JQuery选择器大全原文地址:http://www.cnblogs.com/hulang/archive/2011/01/12/1933771.html

原文地址:https://www.cnblogs.com/bigbearche/p/4824905.html