首頁 >web前端 >js教程 >jQuery 選擇器詳解_jquery

jQuery 選擇器詳解_jquery

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-05-16 16:19:21968瀏覽

  $()函數在很多JavaScript類別庫中都被當作一個選擇器函數來使用,在jQuery中就是.

  $(“#id”)透過id來取得元素,用來取代document.getElementById()函數.

  $(“tagName”)透過標籤名稱來取得元素,用來取代document.getElementsByTagName()函數.

  jQuery的基本語法是:$(selector).action(), selector即選擇器.

jQuery選擇器的分類

  jQuery的選擇器基本上可以分為四大類:

  基本選擇器(basic)

  層次選擇器(level)

  過濾選擇器(filter)

  表單選擇器(form)

  有些類別又可以分為具體的子類別.

基本選擇器

  * 符合所有元素.範例:$(“*")選取所有元素.

  #id根據給定的id匹配元素(最多只回傳一個元素).範例: $("#lastname」)選取id="lastname"的元素.

  .class根據給定的類別名稱匹配元素.範例:$(".intro」)選取所有class=「intro"的元素.

  element根據給定的元素名稱來匹配元素.範例: $(“p")選取所有

元素.

  .class.class 範例: $(".intro.demo」)選取所有且class="demo」的元素.(交集).

  selector1, selector2, …, selectorN, 將每個選擇器配對到的元素合併後一起回傳.(並集).

  除了#id選擇器回傳單一元素外,其他選擇器回傳的都是元素集合.

  這是因為HTML規範裡面id應該是唯一的,所以重複id的元素沒有被考慮.

  如果多個元素的id相同,取這個id也只能取得第一個元素.即取得的jQuery物件的length屬性是1.

  如果要匹配的元素不存在,則都回傳一個空的jQuery物件.

     基本選擇器之間可以組合,用逗號分隔,結果取所有條件的結果的並集.

  當沒有用逗號分隔時,應該是所有條件都滿足的交集.

層次選擇器

  $(“ancestor descendant”) 選取ancestor元素裡的所有descendant後代元素,包括直接子元素和更深嵌套的後代元素.

  例:$(“div span”)選取

裡面的所有的元素.

  注意:選擇器都是全頁掃描,返回一個集合,所有符合選擇條件的元素都會被包括進去.所以多個

下面的都會被選擇.

  $(“parent>child”)選取parent元素下的child子元素,即只有直接子元素被選取.其他後代元素不包括.

  例:$(“div>span”)選取

元素下元素名稱是的子元素.

  $(“prev next”)選取緊接在prev元素後的next元素(同一層級).

  例:$(“.one div”)選取class為one的下一個div元素.

  $(“prev siblings”)選取prev元素之後的所有siblings元素(同一層級).

  例:$(“#two~div”)選取id為two的元素後面的所有

兄弟元素.

  等價方法:

  $(“prev next”)等價於方法$(“prev”).next(“next”);選取prev元素之後緊接著的一個next元素.

  $(“prev~sublings”)等價於方法$(“prev”).nextAll(“sublings”),選取prev元素之後的所有同級的sublings元素.

  而$(“prev”).sublings(“next”)方法選取與prev同輩的所有next元素,與前後位置無關.

過濾選擇器

  過濾選擇器這個大類又分為六個子類:

  基本過濾;內容過濾;可見性過濾;屬性過濾;子元素過濾;表單物件屬性過濾.

基本過濾

  gt和lt分別是greaterthan和lessthan.

內容過濾

可見性過濾

屬性過濾

  屬性過濾是用方括號來識別的.

  注意多個屬性過濾選擇器連在一起的時候,取的是結果的交集.

子元素過濾

  前面基本過濾選擇器裡面index是從0算起的,這裡子元素過濾選擇器的index是從1開始算起的.

表單物件屬性過濾

表單選擇器

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn