js,jq,css選取器

來源:互聯網
上載者:User

標籤:部分   釋放   ted   特定   lan   屬性選取器   file   index   表格   

js擷取節點:

var chils= s.childNodes;  //得到s的全部子節點var par=s.parentNode;   //得到s的父節點var ns=s.nextSbiling;   //獲得s的下一個兄弟節點var ps=s.previousSbiling;  //得到s的上一個兄弟節點var fc=s.firstChild;   //獲得s的第一個子節點var lc=s.lastChile;   //獲得s的最後一個子節點

css選取器:

  基礎選取器

* 通用元素選取器,匹配頁面任何元素(這也就決定了我們很少使用)
#id id選取器,匹配特定id的元素
.class 類別選取器,匹配class包含(不是等於)特定類的元素
element 標籤選取器

  組合選取器

E,F 多元素選取器,用”,分隔,同時匹配元素E或元素F
E F 後代選取器,用空格分隔,匹配E元素所有的後代(不只是子項目、子項目向下遞迴)元素F
E>F 子項目選取器,用”>”分隔,匹配E元素的所有直接子項目
E+F 直接相鄰選取器,匹配E元素之後相鄰同級元素F
E~F 普通相鄰選取器(弟弟選取器),匹配E元素之後同級元素F(無論直接相鄰與否)
.class1.class2 這個姑且也算一個吧,沒什麼名字,匹配類名中既包含class1又包含class2的元素

  屬性選取器

E[attr] 匹配所有具有屬性attr的元素,div[id]就能取到所有有id屬性的div
E[attr=value] 匹配屬性attr值為value的元素,div[id=test],匹配id=test的div
E[attr~=value] 匹配所有屬性attr具有多個空格分隔、其中一個值等於value的元素
E[attr|=value] 匹配所有att屬性具有多個”-”分隔、其中一個值以value開頭的元素,主要用於lang屬性,比如“en”、“en-us”
E[attr ^=value] 匹配屬性attr的值以value開頭的元素
E[attr $=value] 匹配屬性attr的值以value結尾的元素
E[attr *=value] 匹配屬性attr的值包含value的元素

  偽類別選取器(css利器.萬惡的不相容)

E:first-child 匹配元素E的第一個子項目
E:link 匹配所有未被點擊的連結
E:visited 匹配所有已被點擊的連結
E:active 匹配滑鼠已經其上按下、還沒有釋放的E元素
E:hover 匹配滑鼠移至上方其上的E元素
E:focus 匹配獲得當前焦點的E元素
E:lang(c) 匹配lang屬性等於c的E元素
E:enabled 匹配表單中可用的元素
E:disabled 匹配表單中禁用的元素
E:checked 匹配表單中被選中的radio或checkbox元素
E::selection 匹配使用者當前選中的元素
E:root 匹配文檔的根項目,對於HTML文檔,就是HTML元素
E:nth-child(n) 匹配其父元素的第n個子項目,第一個編號為1
E:nth-last-child(n) 匹配其父元素的倒數第n個子項目,第一個編號為1
E:nth-of-type(n) 與:nth-child()作用類似,但是僅匹配使用同種標籤的元素
E:nth-last-of-type(n) 與:nth-last-child() 作用類似,但是僅匹配使用同種標籤的元素
E:last-child 匹配父元素的最後一個子項目,等同於:nth-last-child(1)
E:first-of-type 匹配父元素下使用同種標籤的第一個子項目,等同於:nth-of-type(1)
E:last-of-type 匹配父元素下使用同種標籤的最後一個子項目,等同於:nth-last-of-type(1)
E:only-child 匹配父元素下僅有的一個子項目,等同於:first-child:last-child或 :nth-child(1):nth-last-child(1)
E:only-of-type 匹配父元素下使用同種標籤的唯一一個子項目,等同於:first-of-type:last-of-type或 :nth-of-type(1):nth-last-of-type(1)
E:empty 匹配一個不包含任何子項目的元素,文本節點也被看作子項目
E:not(selector) 匹配不符合當前選取器的任何元素

  虛擬元素選取器

E:first-line 匹配E元素內容的第一行
E:first-letter 匹配E元素內容的第一個字母
E:before 在E元素之前插入產生的內容
E:after 在E元素之後插入產生的內容

jq選取器,過濾器,尋找(功能最全,節點無處可逃):

選取器 執行個體 選取
* $("*") 所有元素
#id $("#lastname") id="lastname" 的元素
.class $(".intro") 所有 class="intro" 的元素
element $("p") 所有 <p> 元素
.class.class $(".intro.demo") 所有 class="intro" 且 class="demo" 的元素
     
:first $("p:first") 第一個 <p> 元素
:last $("p:last") 最後一個 <p> 元素
:even $("tr:even") 所有偶數 <tr> 元素
:odd $("tr:odd") 所有奇數 <tr> 元素
     
:eq(index) $("ul li:eq(3)") 列表中的第四個元素(index 從 0 開始)
:gt(no) $("ul li:gt(3)") 列出 index 大於 3 的元素
:lt(no) $("ul li:lt(3)") 列出 index 小於 3 的元素
:not(selector) $("input:not(:empty)") 所有不為空白的 input 元素
     
:header $(":header") 所有標題元素 <h1> - <h6>
:animated   所有動畫元素
     
:contains(text) $(":contains(‘W3School‘)") 包含指定字串的所有元素
:empty $(":empty") 無子(元素)節點的所有元素
:hidden $("p:hidden") 所有隱藏的 <p> 元素
:visible $("table:visible") 所有可見的表格
     
s1,s2,s3 $("th,td,.intro") 所有帶有匹配選擇的元素
     
[attribute] $("[href]") 所有帶有 href 屬性的元素
[attribute=value] $("[href=‘#‘]") 所有 href 屬性的值等於 "#" 的元素
[attribute!=value] $("[href!=‘#‘]") 所有 href 屬性的值不等於 "#" 的元素
[attribute$=value] $("[href$=‘.jpg‘]") 所有 href 屬性的值包含以 ".jpg" 結尾的元素
     
:input $(":input") 所有 <input> 元素
:text $(":text") 所有 type="text" 的 <input> 元素
:password $(":password") 所有 type="password" 的 <input> 元素
:radio $(":radio") 所有 type="radio" 的 <input> 元素
:checkbox $(":checkbox") 所有 type="checkbox" 的 <input> 元素
:submit $(":submit") 所有 type="submit" 的 <input> 元素
:reset $(":reset") 所有 type="reset" 的 <input> 元素
:button $(":button") 所有 type="button" 的 <input> 元素
:image $(":image") 所有 type="image" 的 <input> 元素
:file $(":file") 所有 type="file" 的 <input> 元素
     
:enabled $(":enabled") 所有啟用的 input 元素
:disabled $(":disabled") 所有禁用的 input 元素
:selected $(":selected") 所有被選取的 input 元素
:checked $(":checked") 所有被選中的 input 元素
jQuery.parent(expr)           //找父元素jQuery.parents(expr)          //找到所有祖先元素,不限於父元素jQuery.children(expr)        //尋找所有子項目,只會找到直接的孩子節點,不會返回所有子孫jQuery.contents()            //尋找下面的所有內容,包括節點和文本。jQuery.prev()                //尋找上一個兄弟節點,不是所有的兄弟節點jQuery.prevAll()             //尋找所有之前的兄弟節點jQuery.next()                //尋找下一個兄弟節點,不是所有的兄弟節點jQuery.nextAll()             //尋找所有之後的兄弟節點jQuery.siblings()            //尋找兄弟節點,不分前後jQuery.find(expr)            //跟jQuery.filter(expr)完全不一樣,jQuery.filter(expr)是從初始的jQuery對象集合中篩選出一部分,而jQuery.find()的返回結果,不會有初始集中篩選出一部分,而jQuery.find()的返回結果,不會有初始集合中的內容,比$("p").find("span")是從元素開始找,等於$("p span").

  

js,jq,css選取器

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.