在 CSS 中,選擇器是一種模式,用於選擇須要添加樣式的元素。css
"CSS" 列指示該屬性是在哪一個 CSS 版本中定義的。(CSS一、CSS2 仍是 CSS3。)html
選擇器 | 例子 | 例子描述 | CSS |
---|---|---|---|
.class | .intro | 選擇 class="intro" 的全部元素。 | 1 |
#id | #firstname | 選擇 id="firstname" 的全部元素。 | 1 |
* | * | 選擇全部元素。 | 2 |
element | p | 選擇全部 <p> 元素。 | 1 |
element,element | div,p | 選擇全部 <div> 元素和全部 <p> 元素。 | 1 |
element element | div p | 選擇 <div> 元素內部的全部 <p> 元素。 | 1 |
element>element | div>p | 選擇父元素爲 <div> 元素的全部 <p> 元素。 | 2 |
element+element | div+p | 選擇緊接在 <div> 元素以後的全部 <p> 元素。 | 2 |
[attribute] | [target] | 選擇帶有 target 屬性全部元素。 | 2 |
[attribute=value] | [target=_blank] | 選擇 target="_blank" 的全部元素。 | 2 |
[attribute~=value] | [title~=flower] | 選擇 title 屬性包含單詞 "flower" 的全部元素。 | 2 |
[attribute|=value] | [lang|=en] | 選擇 lang 屬性值以 "en" 開頭的全部元素。 | 2 |
:link | a:link | 選擇全部未被訪問的連接。 | 1 |
:visited | a:visited | 選擇全部已被訪問的連接。 | 1 |
:active | a:active | 選擇活動連接。 | 1 |
:hover | a:hover | 選擇鼠標指針位於其上的連接。 | 1 |
:focus | input:focus | 選擇得到焦點的 input 元素。 | 2 |
:first-letter | p:first-letter | 選擇每一個 <p> 元素的首字母。 | 1 |
:first-line | p:first-line | 選擇每一個 <p> 元素的首行。 | 1 |
:first-child | p:first-child | 選擇屬於父元素的第一個子元素的每一個 <p> 元素。 | 2 |
:before | p:before | 在每一個 <p> 元素的內容以前插入內容。 | 2 |
:after | p:after | 在每一個 <p> 元素的內容以後插入內容。 | 2 |
:lang(language) | p:lang(it) | 選擇帶有以 "it" 開頭的 lang 屬性值的每一個 <p> 元素。 | 2 |
element1~element2 | p~ul | 選擇前面有 <p> 元素的每一個 <ul> 元素。 | 3 |
[attribute^=value] | a[src^="https"] | 選擇其 src 屬性值以 "https" 開頭的每一個 <a> 元素。 | 3 |
[attribute$=value] | a[src$=".pdf"] | 選擇其 src 屬性以 ".pdf" 結尾的全部 <a> 元素。 | 3 |
[attribute*=value] | a[src*="abc"] | 選擇其 src 屬性中包含 "abc" 子串的每一個 <a> 元素。 | 3 |
:first-of-type | p:first-of-type | 選擇屬於其父元素的首個 <p> 元素的每一個 <p> 元素。 | 3 |
:last-of-type | p:last-of-type | 選擇屬於其父元素的最後 <p> 元素的每一個 <p> 元素。 | 3 |
:only-of-type | p:only-of-type | 選擇屬於其父元素惟一的 <p> 元素的每一個 <p> 元素。 | 3 |
:only-child | p:only-child | 選擇屬於其父元素的惟一子元素的每一個 <p> 元素。 | 3 |
:nth-child(n) | p:nth-child(2) | 選擇屬於其父元素的第二個子元素的每一個 <p> 元素。 | 3 |
:nth-last-child(n) | p:nth-last-child(2) | 同上,從最後一個子元素開始計數。 | 3 |
:nth-of-type(n) | p:nth-of-type(2) | 選擇屬於其父元素第二個 <p> 元素的每一個 <p> 元素。 | 3 |
:nth-last-of-type(n) | p:nth-last-of-type(2) | 同上,可是從最後一個子元素開始計數。 | 3 |
:last-child | p:last-child | 選擇屬於其父元素最後一個子元素每一個 <p> 元素。 | 3 |
:root | :root | 選擇文檔的根元素。 | 3 |
:empty | p:empty | 選擇沒有子元素的每一個 <p> 元素(包括文本節點)。 | 3 |
:target | #news:target | 選擇當前活動的 #news 元素。 | 3 |
:enabled | input:enabled | 選擇每一個啓用的 <input> 元素。 | 3 |
:disabled | input:disabled | 選擇每一個禁用的 <input> 元素 | 3 |
:checked | input:checked | 選擇每一個被選中的 <input> 元素。 | 3 |
:not(selector) | :not(p) | 選擇非 <p> 元素的每一個元素。 | 3 |
::selection | ::selection | 選擇被用戶選取的元素部分。 | 3 |
1.你們在使用selenium元素定位的時候,一般更多使用的是XPATH,css定位方式用得比較少,但有時候css定位方式仍是有一些優點的,css3
優點1:通常狀況下定位速度要比XPATH快web
優點2:語法要比XPATH更簡潔app
常見語法spa
*ssr |
通用元素選擇器,匹配任何元素指針 |
Eorm |
標籤選擇器,匹配全部使用E標籤的元素htm |
.info |
class選擇器,匹配全部class屬性中包含info的元素 |
#footer |
id選擇器,匹配全部id屬性等於footer的元素 |
E,F |
多元素選擇器,同時匹配全部E元素或F元素,E和F之間用逗號分隔 |
E F |
後代元素選擇器,匹配全部屬於E元素後代的F元素,E和F之間用空格分隔 |
E > F |
子元素選擇器,匹配全部E元素的子元素F |
E + F |
毗鄰元素選擇器,匹配緊隨E元素以後的同級元素F (只匹配第一個) |
E ~ F |
同級元素選擇器,匹配全部在E元素以後的同級F元素 |
E[att='val'] |
屬性att的值爲val的E元素 (區分大小寫) |
E[att^='val'] |
屬性att的值以val開頭的E元素 (區分大小寫) |
E[att$='val'] |
屬性att的值以val結尾的E元素 (區分大小寫) |
E[att*='val'] |
屬性att的值包含val的E元素 (區分大小寫) |
E[att1='v1'][att2*='v2'] |
屬性att1的值爲v1,att2的值包含v2 (區分大小寫) |
E:contains('xxxx') |
內容中包含xxxx的E元素 |
E:not(s) |
匹配不符合當前選擇器的任何元素 |
例如這樣一段html代碼的網頁
<div class="formdiv">
<form name="fnfn">
<input name="username" type="text"></input>
<input name="password" type="text"></input>
<input name="continue" type="button"></input>
<input name="cancel" type="button"></input>
<input value="SYS123456" name="vid" type="text">
<input value="ks10cf6d6" name="cid" type="text">
</form>
<div class="subdiv">
<ul id="recordlist">
<p>Heading</p>
<li>Cat</li>
<li>Dog</li>
<li>Car</li>
<li>Goat</li>
</ul>
</div>
</div>
匹配示例:
locator |
匹配 |
css=div css=div.formdiv |
<div class="formdiv"> |
css=#recordlist css=ul#recordlist |
<ul id="recordlist"> |
css=div.subdiv p css=div.subdiv > ul > p |
<p>Heading</p> |
css=form + div |
<div class="subdiv"> |
css=p + li css=p ~ li |
兩者定位到的都是 <li>Cat</li> 可是storeCssCount的時候,前者獲得1,後者獲得4 |
css=form > input[name=username] |
<input name="username"> |
css=input[name$=id][value^=SYS] |
<input value="SYS123456" name="vid" type="hidden"> |
css=input:not([name$=id][value^=SYS]) |
<input name="username" type="text"></input> |
css=li:contains('Goa') |
<li>Goat</li> |
css=li:not(contains('Goa')) |
<li>Cat</li> |
2.css中的結構性定位
結構性定位就是根據元素的父子、同級中位置來定位,css3標準中有定義一些結構性定位僞類如nth-of-type,nth-child,可是使用起來語法很很差理解,這裏就不作介紹了。
Selenium中則是採用了來自Sizzle的css3定位擴展,它的語法更加靈活易懂
Sizzle Css3的結構性定位語法
E:nth(n) E:eq(n) |
在其父元素中的E子元素集合中排在第n+1個的E元素 (第一個n=0) |
E:first |
在其父元素中的E子元素集合中排在第1個的E元素 |
E:last |
在其父元素中的E子元素集合中排在最後1個的E元素 |
E:even |
在其父元素中的E子元素集合中排在偶數位的E元素 (0,2,4…) |
E:odd |
在其父元素中的E子元素集合中排在奇數的E元素 (1,3,5…) |
E:lt(n) |
在其父元素中的E子元素集合中排在n位以前的E元素 (n=2,則匹配0,1) |
E:gt(n) |
在其父元素中的E子元素集合中排在n位以後的E元素 (n=2,在匹配3,4) |
E:only-child |
父元素的惟一一個子元素且標籤爲E |
E:empty |
不包含任何子元素的E元素,注意,文本節點也被看做子元素 |
匹配示例:
例如仍是段的代碼
<div class="subdiv">
<ul id="recordlist">
<p>Heading</p>
<li>Cat</li>
<li>Dog</li>
<li>Car</li>
<li>Goat</li>
</ul>
</div>
locator |
匹配 |
css=ul > li:nth(0) |
<li>Cat</li> |
css=ul > *:nth(0) css=ul > :nth(0) |
<p>Heading</p> |
css=ul > li:first |
<li>Cat</li> |
css=ul > :first |
<p>Heading</p> |
css=ul > *:last css=ul > li:last |
<li>Goat</li> |
css=ul > li:even |
Cat, Car |
css=ul > li:odd |
Dog, Goat |
css=ul > :even |
<p>Heading</p> |
css=ul > p:odd |
[error] not found |
css=ul > li:lt(2) |
<li>Cat</li> |
css=ul > li:gt(2) |
<li>Goat</li> |
css=ul > li:only-child css=ul > :only-child css=ul > *:only-child |
[error] not found (ul沒有only-child) |
css=div.subdiv > :only-child |
<ul id="recordlist"> … … … … </ul> |