标签:
下周的项目应该又要做前台的东西,把JQuery的选择器查询并总结一下,一来加深印象,二来可以作为以后查询.
1.常用的选择器:
$("#idchoose") 选择一个id为idchoose的元素.
$(".class") 选择一个class样式为class的元素.
$("input[name=‘person‘]") 选择一个name为person的input框.
$("h4:contains(‘John‘)") 选择一个包含"John"的h4标题元素.
$("*") 选择文档中的所有的元素
通常情况为了防止因为自己思考有误而导致选择器出错,最简单直接的方法就是在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
标签:
原文地址:http://www.cnblogs.com/bigbearche/p/4824905.html