首頁»JavaScript»jQuery選擇器大全

jQuery選擇器大全

來源:Web開發者 發布時間:2011-12-26 閱讀次數:

在Dom 編程中我們只能使用有限的函數根據id 或者TagName 獲取Dom 對象. 然而在jQuery 中則完全不同,jQuery 提供了異常強大的選擇器用來幫助我們獲取頁面上的對象, 并且將對象以jQuery 包裝集的形式返回。本文主要對常用的jQuery 選擇器進行一個介紹及歸類。

jQuery 選擇器大體上可分為 4 類:基本選擇器、層次選擇器、過濾選擇器、表單選擇器。
其中過濾選擇器可以分為:簡單過濾選擇器、內容過濾選擇器、可見性過濾選擇器、屬性過濾選擇器、子元素過濾選擇器、表單對象屬性過濾選擇器。

基本選擇器:

$("#myELement")    選擇id值等于myElement的元素,id值不能重復在文檔中只能有一個id值是myElement所以得到的是唯一的元素
$("div")                     選擇所有的div標簽元素,返回div元素數組
$(".myClass")           選擇使用myClass類的css的所有元素
$("*")                        選擇文檔中的所有的元素
可以運用多種的選擇方式進行聯合選擇:例如$("#myELement,div,.myclass")

層疊選擇器:

$("form input")         選擇所有的form元素中的input元素
$("#main > *")          選擇id值為main的所有的子元素
$("label + input")     選擇所有的label元素的下一個input元素節點
經測試選擇器返回的是label標簽后面直接跟一個input標簽的所有input標簽元素
$("#prev ~ div")       同胞選擇器
該選擇器返回的為id為prev的標簽元素的所有的屬于同一個父元素的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:ll(4)")              選擇td元素中序號小于4的所有的td元素
$(":header")
$("div:animated")

內容過濾選擇器:

$("div:contains('John')")  選擇所有div中含有John文本的元素
$("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!='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:last-child")           返回所有的div元素的最后一個節點的數組
$("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 事件對象屬性小結

QQ群:WEB開發者官方群(515171538),驗證消息:10000
微信群:加小編微信 849023636 邀請您加入,驗證消息:10000
提示:更多精彩內容關注微信公眾號:全棧開發者中心(fsder-com)
網友評論(共3條評論) 正在載入評論......
理智評論文明上網,拒絕惡意謾罵 發表評論 / 共3條評論
登錄會員中心
大发国际网址 合阳县| 秭归县| 宝坻区| 四子王旗| 额敏县| 博白县| 若羌县| 成都市| 读书| 离岛区| 上栗县| 博爱县| 青浦区| 蒙山县| 措美县| 谷城县| 彭泽县| 桐城市| 宁阳县| 错那县| 上栗县| 敦化市| 南岸区| 遂平县| 潢川县| 潮安县| 沙河市| 水富县| 璧山县| 双牌县| 长宁区| 博野县| 永安市| 合山市| 汉阴县| 耒阳市| 南宫市| 宣威市| 平江县| 南康市| 济宁市| 江孜县| 维西| 仁布县| 鹰潭市| 称多县| 门源| 泰顺县| 岱山县| 梁山县| 荔浦县| 阳城县| 保德县| 花垣县| 枣庄市| 兰溪市| 平和县| 蒙城县| 灵川县| 和硕县| 微博| 闽清县| 临海市| 鸡西市| 长海县| 长白| 武胜县| 浦县| 成武县| 赤峰市| 民丰县| 夏河县| 衡山县| 乡城县| 夏河县| 潞城市| 武强县| 保山市| 和田市| 顺昌县| 博乐市| 福清市| 扶绥县| 盘山县| 衡阳市| 班玛县| 池州市| 南阳市| 达拉特旗| 辰溪县| 榆社县| 拉萨市| 周至县| 新邵县| 怀来县| 阿拉善右旗| 大邑县| 错那县| 正阳县| 怀仁县| 定陶县| 古交市| 清河县| 连平县| 贞丰县| 湾仔区| 三河市| 灵石县| 鄱阳县| 高陵县| 安徽省| 宁安市| 沈阳市| 简阳市| 广东省| 射洪县| 分宜县| 休宁县| 方正县| 同仁县| 汉阴县| 广丰县| 泰安市| 崇礼县| 惠安县| 洛宁县| 滁州市| 水富县| 府谷县| 剑川县| 房山区| 凤庆县| 乌拉特中旗| 黔西| 洛阳市| 马鞍山市| 昌宁县|