WebDriver中执行JavaScript

首先,我们使用如下方式初始化driver:

 

Java代码   收藏代码
  1. WebDriver driver = new FirefoxDriver();  
  2. JavascriptExecutor jse = (JavascriptExecutor)driver;  

 

1.直接传入Javascript代码

可以直接给jse传入javascript代码:

Java代码   收藏代码
  1. jse.executeScript("window.document.getElementById('jingshou').click()";  

2.传入WebElement执行JS:

Java代码   收藏代码
  1. WebElement element = driver.findElement(By.id("jingshou"));  
  2. jse.executeScript("arguments[0].click();", element);  

又或者:

Java代码   收藏代码
  1. jse.executeScript("arguments[0].οnclick=function(){alert('This is my alert!');}", element)  

其中auguments[0]就代表element, 甚至我们可以传入更多的参数,比如

Java代码   收藏代码
  1. WebElement div = driver.findElemnt(By.id("myDiv"));  
  2. jse.executeScript("arguments[0].setAttribute('style', arguments[1])", div, "height: 1000px");  

 通过执行以上代码,我们指定的DIV就新增(修改)了 style {height: 1000px}的属性


在WebDriver中可以使用JavaScript,通地使用JavascriptExector对象

首先要通过向下转型 JavascriptExecutor js = (JavascriptExecutor) driver; 转为JavascriptExector对象

然后再调用executeScript()方法来执行JS。


例:

1. 打开Google首页

2. 通过JS获取网页中的title  --- document.title

3. 获得网页中链接的数量 ----var links = document.getElementsByTagName('A'); return links.length

具体实现如下

[java] view plain copy
  1. package com.example.tests;  
  2. import static org.junit.Assert.*;  
  3. import org.junit.*;  
  4. import org.openqa.selenium.*;  
  5. import org.openqa.selenium.ie.InternetExplorerDriver;  
  6.   
  7. public class test {  
  8.     @Test  
  9.     public void testJavaScriptCalls() {  
  10.         WebDriver driver = new InternetExplorerDriver();  
  11.         driver.get("http://www.google.com.hk");  
  12.         JavascriptExecutor js = (JavascriptExecutor) driver;  
  13.         String title = (String) js.executeScript("return document.title");  
  14.         assertEquals("Google", title);  
  15.         long links = (Long) js.executeScript("var links = "  
  16.                 + "document.getElementsByTagName('A'); "  
  17.                 + "return links.length");  
  18.         assertEquals(32, links);  
  19.         driver.close();  
  20.     }  
  21. }  

从javaScript代码中返回数据,我们需要使用return关键字。基于返回值的类型,我们需要对executeScript()方法进行转型。对于带小数点的值,使用Double类型,非小数值可以使用Long类型,布尔值可以使用Boolean类型,如果返回的是HTML节点,可以使用 WebElement类型,文本值,可以使用String类型。如果返回的是对象列表,基于对象类型的任何值都可以。







你可能感兴趣的:(自动化测试)