2
@Grapes([
    @Grab("org.codehaus.geb:geb-core:0.7.2"),
    @Grab("org.seleniumhq.selenium:selenium-firefox-driver:2.25.0"),
    @Grab("org.seleniumhq.selenium:selenium-support:2.25.0")
])
import geb.Browser
import org.openqa.selenium.firefox.FirefoxDriver

Browser.drive {

  go "http://www.asu.edu/"
  $("li a").each { a ->
     println(a.text())
  }

}

我正在尝试使用该框架a从网页中获取所有链接(由标签表示)。Geb但我未能在下拉列表中捕获这些链接。以这个页面为例,我无法在Colleges & Schools和下捕获下拉列表Map & Locations。在上面代码的输出中,下拉列表中的每一项都是占一行的“空字符串”。输出的开始部分如下:

SIGN IN
ASU Home
My ASU
Colleges & Schools















Map & Locations











Contact ASU
Freshman
Transfer
Graduate
International
Military | Veteran
Home-Educated
Online
Prospective Students
4

1 回答 1

4

这是因为您只能获取可见元素的文本。这样 text() 只返回对用户可见的文本。

看起来当 :hover 伪类应用于它时,该下拉菜单的样式是打开的。Geb和moveToElement 操作中有拖放支持,您可以使用它来将光标指向元素,但它似乎不起作用 - 我发现一些线程表明 Firefox 驱动程序不能很好地处理它。不幸的是,当前无法使用 jQuery 模拟 :hover,因此您唯一的选择是使用Geb 的 jQuery 集成来手动使元素可见:

$('#asu_universal_nav li', 2).find('ul').jquery.show()

之后,调用 text() 时应返回链接中的文本。另一种选择是使下拉菜单不仅在 :hover 时可见,而且在应用类并在 mouseenter/mouseleave 处理程序中添加/删除该类时也可见。但这只有在您可以修改为您正在自动化/测试的页面提供服务的应用程序时才有可能。

于 2012-12-17T01:02:45.630 回答