Selenium Web 自動化 - 如何找到元素


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 }
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM