如何浏览网页链接并使用Selenium再次返回?

时间:2014-10-09 16:22:20

标签: c# selenium selenium-webdriver automated-tests

我正在尝试找到链接文本也在列表footerNames中的网页上的所有超链接。我想单击链接,等待(稍后将进行验证检查),导航回来,然后单击allLinksHrefs列表中的下一个链接(其中应包含所有必需的网页链接元素)。目前我能够找到第一个链接,单击它,导航回然后测试失败。我在C#中使用Selenium WebDriver。提前谢谢。

    public void TestFooterPageLinks()
    {
        List<IWebElement> allLinksHrefs = new List<IWebElement>();
        List<String> allLinksText = new List<String>();
        String currentUrl = Browser.Url;

        List<String> footerNames = new List<String>();
        footerNames.Add("About");
        footerNames.Add("Press");
        footerNames.Add("Safety");
        footerNames.Add("Privacy");
        footerNames.Add("Help");
        footerNames.Add("Terms");
        foreach (IWebElement link in Browser.FindElements(By.TagName("a")))
        {
            if (footerNames.Contains(link.Text))
            {
                if (allLinksHrefs.Contains(link)) {
                    continue;
                }
                else {
                    allLinksHrefs.Add(link);
                    Console.WriteLine(link);
                }
            }
        }
        foreach (IWebElement pageLink in allLinksHrefs)
        {
            Console.WriteLine(pageLink);
            pageLink.Click();
            Console.WriteLine(Browser.Title);
            Browser.Wait(3);
            Browser.Back();
        }
    }
}

2 个答案:

答案 0 :(得分:1)

尝试以这种方式解决您的问题“导航回来之前找到的元素将会过期。因此我们需要更新代码以在导航回来后重新找到元素”

driver.navigate().to("http://www.example.com/");
List<WebElement> links = driver.findElements(By.tagName("a"));
System.out.println(links.size());
for(int i=0; i<links.size(); i++) {
    // Print the link text
    System.out.println(links.get(i).getText());
    // Print the href's
    System.out.println(links.get(i).getAttribute("href"));
    links.get(i).click();
    System.out.println(driver.getTitle());
    System.out.println(driver.getCurrentUrl());
    driver.navigate().back();
    /* after navigating back the elements found previously will be expired. 
       Hence we need to update the code to refind the elements after navigate back.
       so again we write the links = driver.findElements(By.tagName("a")); */
    links = driver.findElements(By.tagName("a"));
}

答案 1 :(得分:-1)

以下是我可能实现的目标:

List<WebElement> links = driver.findElements(By.cssSelector('a'));

上面的每一个都让你感到满意

然后我可以看到几种不同的方法,我将概述一个简单的例子。

Iterator<WebElement> iter = links.iterator();

设置迭代器对象

while (iter.hasNext()) {
    WebElement we = iter.next();
    visitPage(we);
}

然后有支持访问页面功能

public void visitPage(WebElement link) {
    try {
        link.click()
        Console.WriteLine("Visited Page: " + driver.getTitle() + " at url: " + link.text()); //for page title
    } catch (Exception e) {
        //do something clever with error handling
        e.printStackTrace();
    } 
    // navigate back
    driver.manage.navigate.back();  //go back to previous page (maybe don't even care about this)
}
  • 这是未经测试的。