Selenium Web 自動化 - 如何找到元素
2016-07-29
1. 什么是元素?
元素:http://www.w3school.com.cn/html/html_elements.asp
2. 定位方式解析
Selenium WebDriver 提供一個先進的技術來定位 web 頁面元素。Selenium 功能豐富的API 提供了多個定位策略如:Name、ID、CSS 選擇器、XPath 等等,如下圖所示:
一般會用ID來定位,因為它是唯一的,xpath也比較通用,火狐瀏覽器插件:firepath和firebug是快速給出元素的xpath。
另外JQuery也是很好的定位方法
2.1 通過jQuery來定位元素
jQuery提供了find方法,來快速查找頁面元素,但此方法也僅限使用了jquery庫的頁面。
2.1.1 如何判別頁面使用了jQuery
打開火狐瀏覽器,輸入谷歌地址:https://www.google.com.hk/,按F12調出控制台,接着在最下面的箭頭處輸入:“jQuery”,然后回車:
- 若控制台會返回:“function(e, t)” 這就表明此頁面適用了jQuery庫。
- 若控制台會返回錯誤提示:ReferenceError:jQuery is not defined 這就證明當前的頁面沒有適用到jQuery庫
代碼如下:

1 package WayToFindElement; 2 3 import java.util.List; 4 import org.openqa.selenium.JavascriptExecutor; 5 import org.openqa.selenium.WebDriver; 6 import org.openqa.selenium.WebElement; 7 import org.openqa.selenium.firefox.FirefoxDriver; 8 import org.testng.Assert; 9 import org.openqa.selenium.WebDriverException; 10 11 public class FindByJquery { 12 13 public static void main(String[] args) { 14 TestNotLoadJquery(); 15 } 16 17 private static void TestLoadedJquery() { 18 WebDriver driver = new FirefoxDriver(); 19 driver.manage().window().maximize(); 20 JavascriptExecutor jsExecutor = (JavascriptExecutor)driver; 21 driver.get("https://www.baidu.com"); 22 23 List<WebElement> webElements = (List<WebElement>) jsExecutor.executeScript("return jQuery.find('a.mnav')"); 24 Assert.assertEquals(webElements.size(),6); 25 Assert.assertEquals(webElements.get(2).getText(), "hao123"); 26 driver.quit(); 27 } 28 29 private static void TestNotLoadJquery() 30 { 31 WebDriver driver = new FirefoxDriver(); 32 driver.manage().window().maximize(); 33 JavascriptExecutor jsExecutor = (JavascriptExecutor)driver; 34 driver.get("http://www.2345.com/"); 35 if(!jQueryLoaded(jsExecutor)){ 36 //如果檢測到沒有jquery庫就執行注入操作 37 inJectJquery(jsExecutor); 38 } 39 //找到搜索一下按鈕 元素 40 List<WebElement> searchButton = (List<WebElement>) jsExecutor.executeScript("return jQuery.find('input.sch_btn')"); 41 //驗證按鈕的文本 42 Assert.assertEquals(searchButton.get(0).getAttribute("value"), "搜索一下"); 43 driver.quit(); 44 } 45 46 /**注入jQuery支持*/ 47 public static void inJectJquery(JavascriptExecutor jsExecutor){ 48 jsExecutor.executeScript("var headID = document.getElementsByTagName(\"head\")[0];" 49 + "var newScript = document.createElement('script');" 50 + "newScript.type = 'text/Javascript';" 51 + "newScript.src=\"http://code.jquery.com/jquery-2.1.4.min.js\";" 52 + "headID.appendChild(newScript);"); 53 } 54 55 56 /**判斷當前頁面是否使用了jQuery*/ 57 public static Boolean jQueryLoaded(JavascriptExecutor jsExecutor){ 58 Boolean loaded = true; 59 try{ 60 loaded = (Boolean) jsExecutor.executeScript("return jQuery()! = null"); 61 }catch(WebDriverException e){ 62 loaded = false; 63 } 64 65 return loaded; 66 } 67 }