(六)jQuery选择器
生活随笔
收集整理的這篇文章主要介紹了
(六)jQuery选择器
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
jQuery 的選擇器可謂之強(qiáng)大無比,這里簡單地總結(jié)一下常用的元素查找方法:
$("#myELement") 選擇id值等于myElement的元素,id值不能重復(fù)在文檔中只能有一個(gè)id值是myElement所以得到的是唯一的元素 $("div") 選擇所有的div標(biāo)簽元素,返回div元素?cái)?shù)組 $(".myClass") 選擇使用myClass類的css的所有元素 $("*") 選擇文檔中的所有的元素$("#myELement,div,.myclass"); 群組選擇器:選擇多個(gè)元素 層疊選擇器:
$("form input") 選擇所有的form元素中的任意后代input元素 $("div > span") 選擇<div>元素下元素名為<span>的子元素 $("#main > *") 選擇id值為main的所有的子元素 $("label + input") 選擇所有的label元素緊跟著的input元素節(jié)點(diǎn),經(jīng)測試選擇器返回的是label標(biāo)簽后面直接跟一個(gè)input標(biāo)簽的所有input元素 $("#prev ~ div") 同胞選擇器,該選擇器返回的為id為prev的標(biāo)簽元素的所有的屬于同一個(gè)父元素的div標(biāo)簽
基本過濾選擇器:
$("tr:first") 選擇所有tr元素的第一個(gè) $("tr:last") 選擇所有tr元素的最后一個(gè) $("input:not(:checked) + span") 過濾掉:checked的選擇器的所有的input元素$("tr:even") 選擇所有的tr元素的第0,2,4... ...個(gè)元素(注意:因?yàn)樗x擇的多個(gè)元素時(shí)為數(shù)組,所以序號是從0開始) $("tr:odd") 選擇所有的tr元素的第1,3,5... ...個(gè)元素 $("td:eq(2)") 選擇所有的td元素中序號為2的那個(gè)td元素
$("td:gt(4)") 選擇td元素中序號大于4的所有td元素 (序號從0開始) $("td:lt(4)") 選擇td元素中序號小于4的所有的td元素 (序號從0開始)
$(":header") 選擇所有的標(biāo)題元素,例如h1、h2、h3、 $("div:animated") 選取當(dāng)前正在執(zhí)行動畫的元素
$(":focus") 選取當(dāng)前獲取焦點(diǎn)的元素
內(nèi)容過濾選擇器:
$("div:contains('John')") 選擇所有div中含有“John”文本的元素 $("td:empty") 選擇所有的為空(也不包括文本節(jié)點(diǎn))的td元素的數(shù)組 $("div:has(p)") 選擇所有含有p標(biāo)簽的div元素 $("td:parent") 選擇所有的以td為父節(jié)點(diǎn)的元素?cái)?shù)組可視化過濾選擇器:
$("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'結(jié)尾的input元素 $("input[name*='man']") 選擇所有的name屬性包含'news'的input元素 $("input[name|='en']") 選取屬性name等于en或者以en為前綴(該字符串后跟一個(gè)連字符‘-’)的元素$("input[name~='en']") 選取屬性name用空格分隔的值中包含字符en的元素
子元素過濾選擇器:
$("ul li:nth-child(2)"), 選取每個(gè)父元素下索引值為2的元素$("ul li:nth-child(odd)"), 選取每個(gè)父元素下索引值為奇數(shù)的元素
$("ul li:nth-child(3n + 1)") 選取每個(gè)父元素下索引值是(3n+1)的元素 (n從1開始)$("div span:first-child") 返回所有的div元素的第一個(gè)子節(jié)點(diǎn)的數(shù)組 $("div span:last-child") 返回所有的div元素的最后一個(gè)節(jié)點(diǎn)的數(shù)組 $("div button:only-child") 返回所有的div中只有唯一一個(gè)子節(jié)點(diǎn)的所有子節(jié)點(diǎn)的數(shù)組
表單元素選擇器:
$(":input") 選擇所有的表單輸入元素,包括input, textarea, select 和 button $(":text") 選擇所有的text input元素 $(":password") 選擇所有的password input元素 $(":radio") 選擇所有的radio input元素 $(":checkbox") 選擇所有的checkbox input元素 $(":submit") 選擇所有的submit input元素 $(":image") 選擇所有的image input元素 $(":reset")表單元素過濾選擇器:
$(":enabled") 選擇所有的可操作的表單元素 $("#form:enableed"); 選取id為form的表單內(nèi)所有可用元素 $(":disabled") 選擇所有的不可操作的表單元素 $("#form:disableed"); 選取id為form的表單內(nèi)所有不可用元素$(":checked") 選擇所有的被checked的表單元素
$("select option:selected") 選擇所有的select 的子元素中被selected的元素 $(”input[@ name =S_03_22]“).parent().prev().text() 選取一個(gè) name 為”S_03_22″的input text框的上一個(gè)td的text值 $(”input[@ name ^='S_']“).not(”[@ name $='_R']“) 名字以”S_”開始,并且不是以”_R”結(jié)尾的 $(”input[@ name =radio_01][@checked]“).val(); 一個(gè)名為 radio_01的radio所選的值
以下關(guān)于>、+、~、空格; 的案例解析!
$("A B") 查找A元素下面的所有子節(jié)點(diǎn),包括非直接子節(jié)點(diǎn) $("A>B") 查找A元素下面的直接子節(jié)點(diǎn) $("A+B") 查找A元素后面的兄弟節(jié)點(diǎn),包括非直接子節(jié)點(diǎn) $("A~B") 查找A元素后面的兄弟節(jié)點(diǎn),不包括非直接子節(jié)點(diǎn) 1. $("A B") 查找A元素下面的所有子節(jié)點(diǎn),包括非直接子節(jié)點(diǎn)。(查找元素A的任意后代元素B) 例子:找到表單中所有的 input 元素 HTML 代碼: <form><label>Name:</label><input name="name" /><fieldset><label>Newsletter:</label><input name="newsletter" /></fieldset> </form> <input name="none" /> jQuery 代碼: $("form input") 結(jié)果: [ <input name="name" />, <input name="newsletter" /> ] 2. $("A>B") 查找A元素下面的直接子節(jié)點(diǎn) 例子:匹配表單中所有的子級input元素。 HTML 代碼: <form><label>Name:</label><input name="name" /><fieldset><label>Newsletter:</label><input name="newsletter" /></fieldset> </form> <input name="none" /> jQuery 代碼: $("form > input") 結(jié)果: [ <input name="name" /> ]3. $("A+B") 查找A元素后面的兄弟節(jié)點(diǎn),包括非直接子節(jié)點(diǎn) 例子:匹配所有跟在 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") 結(jié)果: [ <input name="name" />, <input name="newsletter" /> ]
4. $("A~B") 查找A元素后面的兄弟節(jié)點(diǎn),不包括非直接子節(jié)點(diǎn) 例子:找到所有與表單同輩的 input 元素 HTML 代碼: <form><label>Name:</label><input name="name" /><fieldset><label>Newsletter:</label><input name="newsletter" /></fieldset> </form> <input name="none" />
jQuery 代碼: $("form ~ input") 結(jié)果: [ <input name="none" /> ]
?
===========分割線========================================================================
更多案例資源:http://blog.csdn.net/code_kk/article/details/54883514
http://www.cnblogs.com/wuchang/archive/2007/01/20/625786.html
轉(zhuǎn)載于:https://www.cnblogs.com/xiangru0921/p/6524016.html
總結(jié)
以上是生活随笔為你收集整理的(六)jQuery选择器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PgSQL · 案例分享 · Postg
- 下一篇: iOS 横竖屏适配