我正在使用带有 java 的 Selenium WebDriver。
我正在从网页中获取所有链接并尝试一个接一个地单击每个链接。我遇到以下错误:
error org.openqa.selenium.StaleElementReferenceException: 在缓存中找不到元素 - 可能页面在查找后发生了变化 命令持续时间或超时:30.01 秒 有关此错误的文档,请访问:http://seleniumhq.org/exceptions/stale_element_reference.html 构建信息:版本:'2.25.0',修订:'17482',时间:'2012-07-18 21:09:54'
这是我的代码:
public void getLinks()throws Exception{
try {
List<WebElement> links = driver.findElements(By.tagName("a"));
int linkcount = links.size();
System.out.println(links.size());
for (WebElement myElement : links){
String link = myElement.getText();
System.out.println(link);
System.out.println(myElement);
if (link !=""){
myElement.click();
Thread.sleep(2000);
System.out.println("third");
}
//Thread.sleep(5000);
}
}catch (Exception e){
System.out.println("error "+e);
}
}
实际上,它显示在输出中
[[FirefoxDriver: XP 上的 firefox (ce0da229-f77b-4fb8-b017-df517845fa78)] -> 标签名称:a]
作为链接,我想消除这些表格结果。
有以下场景没有这么好的主意:
for (WebElement element : webDriver.findElements(locator.getBy())){
element.click();
}
为什么?因为不能保证
element.click();
不会对其他找到的元素产生影响,所以DOM
可能会改变,因此StaleElementReferenceException
.
最好使用以下场景:
int numberOfElementsFound = getNumberOfElementsFound(locator);
for (int pos = 0; pos < numberOfElementsFound; pos++) {
getElementWithIndex(locator, pos).click();
}
这样更好,因为您将始终刷新
WebElement
,即使之前的点击对其有一些影响。
编辑:添加示例
public int getNumberOfElementsFound(By by) {
return webDriver.findElements(by).size();
}
public WebElement getElementWithIndex(By by, int pos) {
return webDriver.findElements(by).get(pos);
}
希望够用
信用去“贷款”。
我也遇到了“过时的异常”,所以我使用了“贷款”答案并且效果很好。如果有人需要知道如何单击结果页面中的每个链接,试试这个 (java)
clickAllHyperLinksByTagName("h3");
其中“h3”标签包含超链接
public static void clickAllHyperLinksByTagName(String tagName){
int numberOfElementsFound = getNumberOfElementsFound(By.tagName(tagName));
System.out.println(numberOfElementsFound);
for (int pos = 0; pos < numberOfElementsFound; pos++) {
getElementWithIndex(By.tagName(tagName), pos).click();
driver.navigate().back();
}
}
public static int getNumberOfElementsFound(By by) {
return driver.findElements(by).size();
}
public static WebElement getElementWithIndex(By by, int pos) {
return driver.findElements(by).get(pos);
}
WebDriver _driver = new InternetExplorerDriver();
_driver.navigate().to("http://www.google.co.in/");
List <WebElement> alllinks = _driver.findElements(By.tagName("a"));
for(int i=0;i<alllinks.size();i++)
System.out.println(alllinks.get(i).getText());
for(int i=0;i<alllinks.size();i++){
alllinks.get(i).click();
_driver.navigate().back();
}
如果您可以使用
WebDriver.get()
而不是 WebElement.click()
来测试链接,另一种方法是将每个找到的 href
的 WebElement
值保存在单独的列表中。这样你就可以避免 StaleElementReferenceException
,因为在离开第一个 WebElement
之后,你不会尝试重用后续的 WebElement.click()
s。
基本示例:
List<String> hrefs = new ArrayList<String>();
List<WebElement> anchors = driver.findElements(By.tagName("a"));
for ( WebElement anchor : anchors ) {
hrefs.add(anchor.getAttribute("href"));
}
for ( String href : hrefs ) {
driver.get(href);
}
//extract the link texts of each link element
for (WebElement elements : linkElements) {
linkTexts[i] = elements.getText();
i++;
}
//test each link
for (String t : linkTexts) {
driver.findElement(By.linkText(t)).click();
if (driver.getTitle().equals(notWorkingUrlTitle )) {
System.out.println("\"" + t + "\""
+ " is not working.");
} else {
System.out.println("\"" + t + "\""
+ " is working.");
}
driver.navigate().back();
}
driver.quit();
}
完整的解释阅读这个POST
List <WebElement> links = driver.findElements(By.tagName("a"));
int linkCount=links.size();
System.out.println("Total number of page on the webpage:"+ linkCount);
String[] texts=new String[linkCount];
int t=0;
for (WebElement text:links){
texts[t]=text.getText();//extract text from link and put in Array
//System.out.println(texts[t]);
t++;
}
for (String clicks:texts) {
driver.findElement(By.linkText(clicks)).click();
if (driver.getTitle().equals("notWorkingUrlTitle" )) {
System.out.println("\"" + t + "\""
+ " is not working.");
} else {
System.out.println("\"" + t + "\""
+ " is working.");
}
driver.navigate().back();
}
driver.quit();
List jobLinks =driver.findElements(By.tagName("loc"));
List<String> texts = new ArrayList<String>();
for (WebElement element : jobLinks) {
texts.add(element.getText());
}
for(String text:texts) {