我的页面上有一些隐藏的按钮。当我单击文本输入时,页面上会显示其中一个按钮。之前:
<div field='login'>
<input type="text">
<button class="submit" style="display: none">Save</button>
</div>
<div field='name'>
<input type="text">
<button class="submit" style="display: none">Save</button>
</div>
点击第二个输入后:
<div field='login'>
<input type="text">
<button class="submit" style="display: none">Save</button>
</div>
<div field='name'>
<input type="text">
<button class="submit">Save</button>
</div>
所以我尝试在我的测试中通过下一个选择器与第二个按钮进行交互:
static content = {
submitButton { $("button.submit") }
}
但我有下一个错误:
isorg.openqa.selenium.ElementNotVisibleException: Element is not currently visible and so may not be interacted with
如果我写:
static content = {
submitButton { $("button.submit", 1) }
}
它可以工作,但我需要使用页面上的第一个可见按钮。有什么问题?
答案 0 :(得分:9)
很遗憾没有css选择器来查找可见元素,但您可以使用Navigator
static content = {
submitButton { $("button.submit").findAll { it.displayed } }
}
及其displayed
property来查找可见的按钮:
{{1}}