![](/img/trans.png)
[英]Not able to click all links on a web page using Java and Selenium Webdriver
[英]Get all the non-hidden links in a webpage and click using Selenium Webdriver
如何使用Selenium WebDriver获取网页中的所有链接并单击(应删除隐藏的链接)?
我想单击页面上可见的链接。
public void linksclick() throws Exception{
System.setProperty("webdriver.chrome.driver", "path of chrome driver");
WebDriver driver = new ChromeDriver();
baseUrl = "www.example.com";
driver.get(baseUrl);
//driver.get(baseUrl);
List<WebElement> allLinks = driver.findElements(By.tagName("a"));
System.out.println("All Links--> " + allLinks.size());
//Fetching an nth Link
System.out.println(" 1st Link is--> " + allLinks.get(1).getText());
//Fetching all the Links
for (int i=0;i<allLinks.size();i++){
String homeWindow;
String currentWindow;
List<WebElement> allLinks1 = driver.findElements(By.tagName("a"));
Thread.sleep(2000);
System.out.println(allLinks1.get(i).getText());
if((allLinks1.get(i).getText() == null | (allLinks1.get(i).getText()).equalsIgnoreCase("")|allLinks1.get(i).getAttribute("href") == null | allLinks1.get(i).getCssValue("font-size")==null | allLinks1.get(i).getCssValue("font-size")==null | allLinks1.get(i).getCssValue("font-size") == null
| allLinks1.get(i).getCssValue("font-weight")== null | allLinks1.get(i).getCssValue("text-align")== null
| allLinks1.get(i).getCssValue("font-family")== null | allLinks1.get(i).getCssValue("color")== null))
{//DO NOTHING
}
else{
Thread.sleep(2000);
System.out.println(allLinks1.get(i).getText());
//Thread.sleep(1000);
homeWindow = driver.getWindowHandle().toString();
allLinks1.get(i).click();
Thread.sleep(2000);
currentWindow = driver.getWindowHandle().toString();
if(homeWindow.contentEquals(currentWindow)){
//Do nothing
}else {
driver.close();
driver.switchTo().window(homeWindow);
//closechild window
//focus on homewindow
}
driver.navigate().to(baseUrl);
}
}
}
请帮我解决。
您可以尝试使用以下方法:
if (allLinks1.get(i).isDisplayed())
{
allLinks1.get(i).click();
}
如果那不能满足您的要求,则可以在上述if语句中包括allLinks1.get(i).isEnabled()
。
您的代码有几个问题,需要对其进行修复才能使其正常工作。
确保您的网址实际上是有效的:“ http://www.example.com ”,而不只是“ www.example.com”。
列表使用从零开始的索引。 因此,请使用allLinks.get(0)
代替allLinks.get(1)
allLinks.get(0)
。 由于网站上只有一个链接,并且您的代码正试图获取列表中的第二个链接,因此您将获得IndexOutOfBoundsException。
那应该可以帮助您的代码运行。
忠告:为变量提供更多描述性名称,以便您的代码有助于注释自身。 例如,看起来像在循环的每次迭代中都为所有链接创建新列表的原因是,这样您就不会有过时的元素。 因此, allLinks1
命名该变量allLinks1
, allLinks1
将其命名为freshListOfAllLinks
,这样您的代码就可以很清楚地看到。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.