我遇到的情况是,单击按钮打开带有搜索结果的新浏览器窗口。
有什么方法可以连接并聚焦到新打开的浏览器窗口吗?
并使用它,然后返回到原始(第一个)窗口。
我遇到的情况是,单击按钮打开带有搜索结果的新浏览器窗口。
有什么方法可以连接并聚焦到新打开的浏览器窗口吗?
并使用它,然后返回到原始(第一个)窗口。
Answers:
您可以在以下窗口之间切换:
// Store the current window handle
String winHandleBefore = driver.getWindowHandle();
// Perform the click operation that opens new window
// Switch to new window opened
for(String winHandle : driver.getWindowHandles()){
driver.switchTo().window(winHandle);
}
// Perform the actions on new window
// Close the new window, if that window no more required
driver.close();
// Switch back to original browser (first window)
driver.switchTo().window(winHandleBefore);
// Continue with original browser (first window)
只是添加到内容...
返回主窗口(默认窗口)。
使用 driver.switchTo().defaultContent();
该脚本可帮助您从父窗口切换到子窗口,然后将cntrl切换回父窗口。
String parentWindow = driver.getWindowHandle();
Set<String> handles = driver.getWindowHandles();
for(String windowHandle : handles)
{
if(!windowHandle.equals(parentWindow))
{
driver.switchTo().window(windowHandle);
<!--Perform your operation here for new window-->
driver.close(); //closing child window
driver.switchTo().window(parentWindow); //cntrl to parent window
}
}
苏里亚,您的方法行不通,原因有两个:
来源: Internet Explorer 8-10中的Selenium WebDriver Windows切换问题
就我而言,IE在注册表编辑后开始检测新的窗口句柄。
制表进程的增长:设置IE创建“新制表”进程的速率。
“最大数量”(Max-Number)算法:这指定在特定的强制完整性级别(MIC)下,单个帧会话的单个隔离会话可以执行的选项卡进程的最大数量。相对值是:
- TabProcGrowth = 0:选项卡和框架在同一进程中运行;跨MIC级别的帧没有统一。
- TabProcGrowth = 1:给定帧过程的所有选项卡在给定MIC级别的单个选项卡过程中运行。
浏览器: IE11 x64(缩放:100%)
操作系统: Windows 7 x64
硒: 3.5.1
WebDriver: IEDriverServer x64 3.5.1
public static String openWindow(WebDriver driver, By by) throws IOException {
String parentHandle = driver.getWindowHandle(); // Save parent window
WebElement clickableElement = driver.findElement(by);
clickableElement.click(); // Open child window
WebDriverWait wait = new WebDriverWait(driver, 10); // Timeout in 10s
boolean isChildWindowOpen = wait.until(ExpectedConditions.numberOfWindowsToBe(2));
if (isChildWindowOpen) {
Set<String> handles = driver.getWindowHandles();
// Switch to child window
for (String handle : handles) {
driver.switchTo().window(handle);
if (!parentHandle.equals(handle)) {
break;
}
}
driver.manage().window().maximize();
}
return parentHandle; // Returns parent window if need to switch back
}
/* How to use method */
String parentHandle = Selenium.openWindow(driver, by);
// Do things in child window
driver.close();
// Return to parent window
driver.switchTo().window(parentHandle);
上面的代码包含一个if-check,以确保您没有切换到父窗口,因为Set<T>
Java中没有保证的顺序。WebDriverWait
如下所述,似乎增加了成功的机会。
浏览器可能需要一些时间来确认新窗口,并且您可能会在弹出窗口出现之前陷入switchTo()循环中。
您会自动假定getWindowHandles()返回的最后一个窗口将是最后打开的窗口。不一定是正确的,因为不能保证以任何顺序返回它们。
您可以使用:
driver.SwitchTo().Window(WindowName);
其中WindowName是一个字符串,代表您要将焦点切换到的窗口的名称。完成后,使用原始窗口的名称再次调用此函数以返回到该窗口。
我使用迭代器和while循环来存储各种窗口句柄,然后来回切换。
//Click your link
driver.findElement(By.xpath("xpath")).click();
//Get all the window handles in a set
Set <String> handles =driver.getWindowHandles();
Iterator<String> it = handles.iterator();
//iterate through your windows
while (it.hasNext()){
String parent = it.next();
String newwin = it.next();
driver.switchTo().window(newwin);
//perform actions on new window
driver.close();
driver.switchTo().window(parent);
}
main you can do :
String mainTab = page.goToNewTab ();
//do what you want
page.backToMainPage(mainTab);
What you need to have in order to use the main
private static Set<String> windows;
//get all open windows
//return current window
public String initWindows() {
windows = new HashSet<String>();
driver.getWindowHandles().stream().forEach(n -> windows.add(n));
return driver.getWindowHandle();
}
public String getNewWindow() {
List<String> newWindow = driver.getWindowHandles().stream().filter(n -> windows.contains(n) == false)
.collect(Collectors.toList());
logger.info(newWindow.get(0));
return newWindow.get(0);
}
public String goToNewTab() {
String startWindow = driver.initWindows();
driver.findElement(By.cssSelector("XX")).click();
String newWindow = driver.getNewWindow();
driver.switchTo().window(newWindow);
return startWindow;
}
public void backToMainPage(String startWindow) {
driver.close();
driver.switchTo().window(startWindow);
}
因此,许多此类解决方案的问题是您假设窗口立即出现(没有立即发生,并且在IE中发生的情况明显少于立即发生)。另外,您假设单击元素之前只有一个窗口,但情况并非总是如此。IE也不会以可预测的顺序返回窗口句柄。因此,我将执行以下操作。
public String clickAndSwitchWindow(WebElement elementToClick, Duration
timeToWaitForWindowToAppear) {
Set<String> priorHandles = _driver.getWindowHandles();
elementToClick.click();
try {
new WebDriverWait(_driver,
timeToWaitForWindowToAppear.getSeconds()).until(
d -> {
Set<String> newHandles = d.getWindowHandles();
if (newHandles.size() > priorHandles.size()) {
for (String newHandle : newHandles) {
if (!priorHandles.contains(newHandle)) {
d.switchTo().window(newHandle);
return true;
}
}
return false;
} else {
return false;
}
});
} catch (Exception e) {
Logging.log_AndFail("Encountered error while switching to new window after clicking element " + elementToClick.toString()
+ " seeing error: \n" + e.getMessage());
}
return _driver.getWindowHandle();
}
如果您有一个以上的浏览器(使用Java 8)
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
public class TestLink {
private static Set<String> windows;
public static void main(String[] args) {
WebDriver driver = new FirefoxDriver();
driver.get("file:///C:/Users/radler/Desktop/myLink.html");
setWindows(driver);
driver.findElement(By.xpath("//body/a")).click();
// get new window
String newWindow = getWindow(driver);
driver.switchTo().window(newWindow);
// Perform the actions on new window
String text = driver.findElement(By.cssSelector(".active")).getText();
System.out.println(text);
driver.close();
// Switch back
driver.switchTo().window(windows.iterator().next());
driver.findElement(By.xpath("//body/a")).click();
}
private static void setWindows(WebDriver driver) {
windows = new HashSet<String>();
driver.getWindowHandles().stream().forEach(n -> windows.add(n));
}
private static String getWindow(WebDriver driver) {
List<String> newWindow = driver.getWindowHandles().stream()
.filter(n -> windows.contains(n) == false).collect(Collectors.toList());
System.out.println(newWindow.get(0));
return newWindow.get(0);
}
}