首页 > 代码库 > WebDriver中执行JavaScript

WebDriver中执行JavaScript

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

1     WebDriver driver = new FirefoxDriver();  
2     JavascriptExecutor jse = (JavascriptExecutor)driver; 

 

1.直接传入JavaScript代码

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

1  jse.executeScript("window.document.getElementById(‘jingshou‘).click()";  

 

2.传入WebElement执行js:

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

又或者:

1     jse.executeScript("arguments[0].onclick=function(){alert(‘This is my alert!‘);}", element)  

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

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

具体实现如下

 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类型。如果返回的是对象列表,基于对象类型的任何值都可以。

 

WebDriver中执行JavaScript