編碼的世界 / 優質文選 / 生涯

Selenium - CSS Selector


2021年9月20日
-   

用CSS(即層疊樣式表Cascading Stylesheet) Selector來定位(locate)頁面上的元素(Elements)。
Selenium官網的Document裏極力推薦使用CSS locator,而不是XPath來定位元素,原因是CSS locator比XPath locator速度快,特別是在IE下面(IE沒有自己的XPath 解析器(Parser))。用CSS Selector能非常精准的定位到想測試的Elements,因為前端開發人員就是用CSS Selector設定頁面上每一個元素的樣式,無論那個元素的位置有多複雜,他們能定位到,那我們也能定位到。
讀一下這個文檔就能明白大部分的CSS Selector了
http://www.w3.org/TR/css3-selectors/
 
1.button上有class屬性的,如:
 <button id="ext-eng=1026" class="x-right-button">
 可以這樣寫:
 css=button.x-right-button
 .代表class
 如果class裏帶的空格,用.來代替空格如:
 <button class="x-btn-text module_picker_icon">
 可以這樣寫:
 css=button.x-btn-text.module_picker_icon
 
2.如果想用別的屬性值定位,用方括號屬性名=屬性值的方式,如:
 <abbr>Abc<abbr/>
 css=abbr[title="Abc"]
 
3.如果button上有id屬性的,如:
 <input id="ag_name" type="text">
 可以這樣寫:
 css=input#ag_name 
 或者直接寫 
 css=#ag_name
 #代表id
 但是在實際應該中,如果有元素固定id的,可以直接用id locator,這樣寫:
 id=ag_name
 這通常是在Form裏的input元素, 需要用戶填寫內容然後提交的部分,也是最簡單的部分。
 沒有固定id的,通常是由javascript框架自動生成的id如,每次加載頁面都會改變的,如:
 <button id="ext-eng-1026" >,下回可能就是<button id="ext-eng-2047">
 這種情況不能使用id屬性來定位。
 如果你想定位一個顯示OK的Button,但頁面上有幾個Button,id是自動生成的,class是一樣的,我又想用一個簡單點的CSS locator的時候,
 <button id="ext-eng-1026" class="x-right-button">OK</button>
 <button id="ext-eng-1027" class="x-right-button">Cancel</button>
 可以這樣寫: 
 css=button.x-right-button:contains("OK")
 :contains是個Pseudo-class,用冒號開頭,括號裏是內容。
 Pseudo-classes是CSS提供的偽類,用來訪問頁面上DOM tree之外的信息,還有Pseudo-elements 用來最精准的定位頁面上的某一行文字,甚至某一行文字的第一個字 母。 具體可以研究一下css3 selector文檔的Chapter 6.6 Pseudo-classes 和 Chapter 7 Pseudo-elements
 
4.基本上用XPath能定位的元素,都能用CSS Selector定位到。
  它兩最相似的是這樣寫: 
  <table><tr><td><div><span>abcd</span><span>1234</span></div></td></tr></table>
  xpath=//table/tr/td/div/span[1]
  css=table>tr>td>div>span:nth-child(1)
  *xpath沒在頁面上測試過。
  一個非常好的blog,不看可惜了。
 
http://saucelabs.com/blog/index.php/2009/10/selenium-tip-of-the-week-start-improving-your-locators/
 
http://bbs.opentest.cn/thread-594-1-1.html
 
5.綜上所述,就是:
  有固定id的用id selector, 
  沒有固定id的用css selector。 
  Pseudo-selements :contains()很好用。

熱門文章